반응형
문제(출처)
대학생 새내기들의 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%
내 풀이
import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.IOException;import java.io.InputStreamReader;import java.io.OutputStreamWriter;import java.text.DecimalFormat;import java.util.ArrayList;
public class Main { public static void main(String args[]) { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); try { int num_len = Integer.parseInt(br.readLine()); // 몇 행을 만들지 입력 값을 받는다. int col_len = 0; // 열의 길이를 저장한다. String[] str = new String[num_len]; // 열의 정보를 배열에 저장한다. int sum = 0; // 총 합을 저장한다. double avg = 0; // 평균을 저장한다. int avg_cnt = 0; // 평균을 초과하는 학생을 세어 저장한다. double result = 0; // 결과를 저장한다. for(int i = 0; i < num_len; i++) {// 첫 번째 입력 값만큼 반복한다. str = br.readLine().split(" ");// 학생 수와 과목 점수를 받아 str배열로 저장한다. col_len= Integer.parseInt(str[0]);// str배열에 저장한 점수 중 첫 번째 열에 있는 점수 학생 수를 col_len에 저장한다. for(int j = 1; j <= col_len; j++) {// 배열의 두번 째 값이 1부터 하며 학생수와 같을 때 까지 1씩 증분한다. sum += Integer.parseInt(str[j]);// 과목 점수를 총합에 합하여 저장한다. } avg = sum/(col_len);// 총합과 학생수를 평균 낸다. for(int k = 1; k <=col_len; k++) {// 배열의 두번 째 값이 1부터 하며 학생수와 같을 때 까지 1씩 증분한다. if(avg < Integer.parseInt(str[k]) ) {// 평균을 초과 하는 학생을 비교하고 넘는다면 인원수를 증분한다. avg_cnt++; } } result = ((double)(avg_cnt)/(col_len))*100;// 평균이 넘는 학생수와 학생수를 나누어 결과로 출력한다. System.out.printf("%.3f", result); System.out.println("%"); avg_cnt = 0; sum = 0; avg = 0; result = 0; } } catch (NumberFormatException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } }}
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.text.DecimalFormat;
import java.util.ArrayList;
public class Main {
public static void main(String args[]) {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
try {
int num_len = Integer.parseInt(br.readLine());
// 몇 행을 만들지 입력 값을 받는다.
int col_len = 0;
// 열의 길이를 저장한다.
String[] str = new String[num_len];
// 열의 정보를 배열에 저장한다.
int sum = 0;
// 총 합을 저장한다.
double avg = 0;
// 평균을 저장한다.
int avg_cnt = 0;
// 평균을 초과하는 학생을 세어 저장한다.
double result = 0;
// 결과를 저장한다.
for(int i = 0; i < num_len; i++) {
// 첫 번째 입력 값만큼 반복한다.
str = br.readLine().split(" ");
// 학생 수와 과목 점수를 받아 str배열로 저장한다.
col_len= Integer.parseInt(str[0]);
// str배열에 저장한 점수 중 첫 번째 열에 있는 점수 학생 수를 col_len에 저장한다.
for(int j = 1; j <= col_len; j++) {
// 배열의 두번 째 값이 1부터 하며 학생수와 같을 때 까지 1씩 증분한다.
sum += Integer.parseInt(str[j]);
// 과목 점수를 총합에 합하여 저장한다.
}
avg = sum/(col_len);
// 총합과 학생수를 평균 낸다.
for(int k = 1; k <=col_len; k++) {
// 배열의 두번 째 값이 1부터 하며 학생수와 같을 때 까지 1씩 증분한다.
if(avg < Integer.parseInt(str[k]) ) {
// 평균을 초과 하는 학생을 비교하고 넘는다면 인원수를 증분한다.
avg_cnt++;
}
}
result = ((double)(avg_cnt)/(col_len))*100;
// 평균이 넘는 학생수와 학생수를 나누어 결과로 출력한다.
System.out.printf("%.3f", result);
System.out.println("%");
avg_cnt = 0;
sum = 0;
avg = 0;
result = 0;
}
} catch (NumberFormatException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
내 풀이 해석
주석(의사코드) 참조
과목의 평균이 아닌 평균이 넘는 학생들의 평균을 구하는 문제.
입력 받은 수 만큼의 행과 열을 입력 받습니다.
한 행의 평균을 구하고 해당 행의 평균을 넘는 학생을 구하고 출력합니다.
avg_cnt, sum, avg, result를 초기화 해주는게 포인트입니다.
아쉬운 점
DecimalFormat을 이용하려고 했습니다.
소수점 10^-3으로 표현해야 하는데 0으로 떨어지는 수에 대해서는 40.0%으로 출력 되어서 System.out.print를 이용했습니다.
반응형
'개발(합니다) > 알고리즘&코테' 카테고리의 다른 글
알고리즘 단계별로 풀어보기 : BOJ-4673(셀프넘버) (0) | 2018.12.17 |
---|---|
알고리즘 단계별로 풀어보기 : BOJ-1110(더하기싸이클) (0) | 2018.12.16 |
알고리즘 단계별로 풀어보기 : BOJ-1546(평균) (0) | 2018.12.16 |
알고리즘 단계별로 풀어보기 : BOJ-10871(x보다작은수) (0) | 2018.12.16 |
알고리즘 단계별로 풀어보기 : BOJ-10817(세 수) (0) | 2018.12.16 |