평균은 넘겠지

동동·2023년 4월 6일
0
post-thumbnail

평균은 넘겠지

레벨: 브론즈 1
날짜: 2023년 4월 6일 오후 9:45
문제번호: 4344
알고리즘: 사칙연산, 수학

시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초256 MB258024929697632835.823%

문제

대학생 새내기들의 90%는 자신이 반에서 평균은 넘는다고 생각한다. 당신은 그들에게 슬픈 진실을 알려줘야 한다.

입력

첫째 줄에는 테스트 케이스의 개수 C가 주어진다.

둘째 줄부터 각 테스트 케이스마다 학생의 수 N(1 ≤ N ≤ 1000, N은 정수)이 첫 수로 주어지고, 이어서 N명의 점수가 주어진다. 점수는 0보다 크거나 같고, 100보다 작거나 같은 정수이다.

출력

각 케이스마다 한 줄씩 평균을 넘는 학생들의 비율을 반올림하여 소수점 셋째 자리까지 출력한다.

예제 입력 1

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

예제 출력 1

40.000%
57.143%
33.333%
66.667%
55.556%

풀이

#include <iostream>

using namespace std;

int main() {
    int testcase;
    cin >> testcase;
    float avg[testcase][1002];
    for(int i=0;i<testcase; i++) {
        for(int j=0; j<1002; j++)
            avg[i][j] = 0;
    }
    
    //데이터 입력 및 계산
    for(int i=0; i<testcase; i++) {
        int numstudent;
        cin>>numstudent;
        for(int j=0; j<numstudent; j++) {
            cin>>avg[i][j];
            avg[i][1000] = avg[i][1000] + avg[i][j];
        }
        avg[i][1000] = avg[i][1000] / (float)numstudent; //각 배열 1000에 평균값 저장

        //평균 넘는 학생들 비율 계산헤서 각 배열 1001에 저장
        for(int j=0; j<numstudent; j++) {
            if(avg[i][j]>avg[i][1000])
                avg[i][1001]++;
        }    
        avg[i][1001] = avg[i][1001]/numstudent;
    }

    //소수점 표현
    cout<<fixed;
    cout.precision(3);

    //비율 출력
    for(int i=0; i<testcase; i++) {
        cout<<avg[i][1001]*100<<"%"<<endl;
    }
    return 0;
}
profile
알고리즘 문제를 주로 업로드합니다.

0개의 댓글