일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 | 31 |
Tags
- 리눅스
- 원격저장소
- 플라스크
- SQL
- 디버깅
- 가상환경
- MySQL
- 운영체제
- 엑셀
- 디렉토리
- 역할
- 데이터베이스
- 라이브러리
- 기초
- OpenCV
- matplotlib
- 코랩
- 예제
- 아나콘다
- 단축키
- 파이썬
- vscode
- 우분투
- 데이터분석
- 판다스
- 에러
- 깃허브
- 프로그래머스
- 머신러닝
- visual studio code
Archives
- Today
- Total
취미와 밥줄사이
[Algorithm] 백준 4344번: 평균은 넘겠지 본문
문제
대학생 새내기들의 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%
풀이
testCase = int(input())
for i in range(testCase): # [0, 1, 2, 3, 4]
score = list(map(int, input().split())) # [학생 수, 점수1, 점수2, 점수3, 점수4, 점수5]
means = sum(score[1:]) / score[0] # 점수 합 / 학생 수
cnt = 0 # 평균이상인 학생 수
for j in range(1, len(score)): # (1, 2, 3, ...)
if score[j] > means: # 평균보다 점수가 높으면
cnt = cnt + 1 # cnt에 추가
print('%.3f'%(cnt / score[0] * 100)+'%' )
REFERENCE
https://www.acmicpc.net/problem/4344
'Python > 알고리즘' 카테고리의 다른 글
[Algorithm] 백준 11720번: 숫자의 합 (0) | 2021.12.05 |
---|---|
[Algorithm] 백준 11654번: 아스키 코드 (0) | 2021.12.05 |
[Algorithm] 백준 8958번: OX퀴즈 (0) | 2021.12.02 |
[Algorithm] 백준 3052번: 나머지 (0) | 2021.12.01 |
[Algorithm] 백준 2588번: 곱셈 (0) | 2021.11.29 |