[알고리즘] 등수 구하기

hoonie·2021년 7월 27일
0

알고리즘

목록 보기
10/15
post-thumbnail
post-custom-banner

문제

N(1<=N<=100)명의 학생의 국어점수가 입력되면 각 학생의 등수를 입력된 순서대로 출력하는 프로그램을 작성하세요.

▣ 입력설명
첫 줄에 N(3<=N<=1000)이 입력되고, 두 번째 줄에 국어점수를 의미하는 N개의 정수가 입력 된다. 같은 점수가 입력될 경우 높은 등수로 동일 처리한다. 즉 가장 높은 점수가 92점인데 92점이 3명 존재하면 1등이 3명이고 그 다음 학생은 4등이 된다.

▣ 출력설명
입력된 순서대로 등수를 출력한다.

▣ 입력예제
87 89 92 100 76
▣ 출력예제 43215

   function solution(arr) {
        let answer = Array.from({ length: arr.length }, () => 1);
        for (let i = 0; i < arr.length; i++) {
          for (let j = 0; j < arr.length; j++) {
            if (arr[i] < arr[j]) answer[i]++;
          }
        }
        return answer;
      }

      let arr = [89, 89, 92, 100, 76];
      console.log(solution(arr));

설명

우선, 간단한 임의의 등수 배열( 모두다 일단 1등으로) 만들어줍니다.
그리고 이중 반복문을 돌려 다른 모든 배열 원소랑 비교를 해가면서 만약 다른 배열이 더 크다면 그만큼 등수를 내립니다.

post-custom-banner

0개의 댓글