대학생 새내기들의 90%는 자신이 반에서 평균은 넘는다고 생각한다. 당신은 그들에게 슬픈 진실을 알려줘야 한다.
첫째 줄에는 테스트 케이스의 개수 C가 주어진다.
둘째 줄부터 각 테스트 케이스마다 학생의 수 N(1 ≤ N ≤ 1000, N은 정수)이 첫 수로 주어지고, 이어서 N명의 점수가 주어진다. 점수는 0보다 크거나 같고, 100보다 작거나 같은 정수이다.
각 케이스마다 한 줄씩 평균을 넘는 학생들의 비율을 반올림하여 소수점 셋째 자리까지 출력한다.
5
5 50 50 70 80 100
7 100 95 90 80 70 60 50
3 70 90 80
3 70 90 81
9 100 99 98 97 96 95 94 93 91
40.000%
57.143%
33.333%
66.667%
55.556%
[mdn] Array.prototype.reduce((누적된 값,[option])) => 연산식, [누적된 값의 초기값])
const fs = require("fs");
const filePath = process.platform === "linux" ? "/dev/stdin" : "./input.txt";
let input = fs.readFileSync(filePath).toString().split("\n");
let c = +input[0];
for (let i = 1; i <= c; i++) {
let sum = 0;
let count = 0;
let scores = input[i].split(" ").map((x) => +x);
const n = scores[0];
for (let j = 1; j <= n; j++) {
sum += scores[j];
}
const avg = sum / n;
for (let k = 1; k <= n; k++) {
if (avg < scores[k]) count++;
}
console.log(((count / n) * 100).toFixed(3) + "%");
}
let input = require('fs').readFileSync('/dev/stdin').toString().split('\n');
let num = input[0] * 1;
for (let i = 1; i <= num; i++) {
let score = input[i].split(' ');
let num2 = score.shift() * 1;
let count = 0;
let avg = score.reduce((acc, v) => acc += v * 1, 0);
avg /= num2;
for (let j = 0; j < num2; j++) {
if (score[j] > avg) {
count++;
}
}
let result = ((count / num2) * 100).toFixed(3);
console.log(result + "%");
}