알고리즘 문제풀이/백준
[백.단.풀.4] 평균 (1546)
뻠스키
2019. 3. 12. 14:36
Step : <if문 사용해보기>
Title : " 평균 "
시간 제한 | 메모리 제한 | 제출 | 정답 | 맞은 사람 | 정답 비율 |
---|---|---|---|---|---|
2 초 | 128 MB | 8855 | 3670 | 3340 | 45.080% |
문제
세준이는 기말고사를 망쳤다. 세준이는 점수를 조작해서 집에 가져가기로 했다. 일단 세준이는 자기 점수 중에 최대값을 골랐다. 이 값을 M이라고 한다. 그리고 나서 모든 점수를 점수/M*100으로 고쳤다.
예를 들어, 세준이의 최고점이 70이고, 수학점수가 50이었으면 수학점수는 50/70*100이 되어 71.43점이 된다.
세준이의 성적을 위의 방법대로 새로 계산했을 때, 새로운 평균을 구하는 프로그램을 작성하시오.
입력
첫째 줄에 시험 본 과목의 개수 N이 주어진다. 이 값은 1000보다 작거나 같다. 둘째 줄에 세준이의 현재 성적이 주어진다. 이 값은 100보다 작거나 같은 음이 아닌 정수이고, 적어도 하나의 값은 0보다 크다.
출력
첫째 줄에 새로운 평균을 소수점 셋째 자리에서 반올림해 둘째자리까지 출력한다.
예제 입력
3 40 80 60
예제 출력
75.00
이것 또한 쉬운 문제다...
그런데 이번에도 틀렸습니다 가 3번이나 나왔다....
N 번을 받는다는데, 3번만 받도록 설정해놓고,
하나 안고친 줄 알고 하나 고치고 내고,
하나 더 있길래 또 고치고,
또 고치고,,,,ㄷㄷ
하.. 문제 꼭 똑바로 읽고 푸는 습관을 들이자!!! (쉽다고 방심 X)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <malloc.h> int N; double score[1001]; double sum, max; int main() { scanf("%d", &N); for (int i = 0; i < N; i++) { scanf("%lf", &score[i]); if (max < score[i]) max = score[i]; } for (int i = 0; i < N; i++) { score[i] = score[i] / max * 100; sum += score[i]; } printf("%.2lf\n", (double)sum / N); return 0; } | cs |