문제
설명
N명의 학생의 국어점수가 입력되면 각 학생의 등수를 입력된 순서대로 출력하는 프로그램을 작성하세요.
같은 점수가 입력될 경우 높은 등수로 동일 처리한다.
즉 가장 높은 점수가 92점인데 92점이 3명 존재하면 1등이 3명이고 그 다음 학생은 4등이 된다.
입력
첫 줄에 N(3<=N<=100)이 입력되고, 두 번째 줄에 국어점수를 의미하는 N개의 정수가 입력된다.
출력
입력된 순서대로 등수를 출력한다.
선생님 풀이
import java.util.Scanner;
public class Main2_8 {
public int[] Solution(int n, int[] arr) {
int[] answer = new int[n];
int rank=0, cnt=0;
for (int i = 0; i < n; i++) { // 배열 n개에 대해 i번 반복
cnt=1;
for (int j = 0; j < n; j++) { // 최대값 찾는 작업 j번 반복
if(arr[j]>arr[i]) cnt++;
}
answer[i] = cnt;
}
return answer;
}
public static void main(String[] args) {
Main2_8 T = new Main2_8();
Scanner sc = new Scanner(System.in);
int num = sc.nextInt();
int[] arr = new int[num];
for (int i = 0; i < num; i++) {
arr[i] = sc.nextInt();
}
for(int x : T.Solution(num, arr))
System.out.print(x + " ");
}
}
결과
'Algorithm > Inflearn' 카테고리의 다른 글
[Inflearn] 영리한 프로그래밍을 위한 알고리즘 - 순환 (Recursion) 의 응용 : Counting Cells in a Blob (0) | 2022.11.21 |
---|---|
[Inflearn] 자바 알고리즘 문제풀이 #02-09 9. 격자판 최대합 (0) | 2022.11.21 |
[Inflearn] 영리한 프로그래밍을 위한 알고리즘 - 순환 (Recursion) 의 응용 : 미로찾기 (1) | 2022.11.16 |
[Inflearn] 자바 알고리즘 문제풀이 #02-07 7. 점수계산 (0) | 2022.11.16 |
[Inflearn] 영리한 프로그래밍을 위한 알고리즘 - 순환 (Recursion) 의 개념과 기본 예제 3 (0) | 2022.11.15 |