반응형
문제
대학생 새내기들의 90%는 자신이 반에서 평균은 넘는다고 생각한다. 당신은 그들에게 슬픈 진실을 알려줘야 한다.
입력
첫째 줄에는 테스트 케이스의 개수 C가 주어진다.
둘째 줄부터 각 테스트 케이스마다 학생의 수 N(1 ≤ N ≤ 1000, N은 정수)이 첫 수로 주어지고, 이어서 N명의 점수가 주어진다. 점수는 0보다 크거나 같고, 100보다 작거나 같은 정수이다.
출력
각 케이스마다 한 줄씩 평균을 넘는 학생들의 비율을 반올림하여 소수점 셋째 자리까지 출력한다.
#include<iostream>
#include<queue>
#include<vector>
#include<cmath>
#include<string.h>
#include<algorithm>
#include<string>
using namespace std;
int arr[1000];
int main() {
int tc;
cin >> tc;
for (int t = 0; t < tc; t++)
{
int N;
cin >> N;
int sum = 0;
for (int i = 0; i < N; i++)
{
cin >> arr[i];
sum += arr[i];
}
double mean = sum / N;
double ans = 0;
for (int i = 0; i < N; i++)
{
if (arr[i] > mean)
ans++;
}
ans /= N;
ans *= 100;
ans *= 1000;
ans = round(ans);
ans /= 1000;
printf("%.3f%\n", ans);
}
}
반응형
'Algorithm' 카테고리의 다른 글
[삼성 기출] 백준 20055번 컨베이어 벨트 위의 로봇 (0) | 2020.10.21 |
---|---|
[컨벡스 헐 단계] 백준 1708번 볼록 껍질 (0) | 2020.10.20 |
[1차원 배열 단계] 백준 8958번 OX퀴즈 (0) | 2020.10.19 |
[1차원 배열 단계] 백준 1546번 평균 (0) | 2020.10.19 |
[1차원 배열 단계] 백준 3052번 나머지 (0) | 2020.10.19 |