본문 바로가기
알고리즘 Node.js

백준 1546문제. 평균(스페셜 저지)

by 반갑조? 2025. 3. 13.

문제

문제: 세준이는 기말고사를 망쳤다. 세준이는 점수를 조작해서 집에 가져가기로 했다. 일단 세준이는 자기 점수 중에 최댓값을 골랐다. 이 값을 M이라고 한다. 그리고 나서 모든 점수를 점수/M*100으로 고쳤다.

         예를 들어, 세준이의 최고점이 70이고, 수학점수가 50이었으면 수학점수는 50/70*100이 되어 71.43점이 된다.

         세준이의 성적을 위의 방법대로 새로 계산했을 때, 새로운 평균을 구하는 프로그램을 작성하시오.

입력: 첫째 줄에 시험 본 과목의 개수 N이 주어진다. 이 값은 1000보다 작거나 같다. 둘째 줄에 세준이의 현재 성적이 주어진다. 이 값은 100보다 작거나 같은 음이 아닌 정수이고, 적어도 하나의 값은 0보다 크다.

출력: 첫째 줄에 새로운 평균을 출력한다. 실제 정답과 출력값의 절대오차 또는 상대오차가 10-2 이하이면 정답이다.

          10-2 이하의 오차를 허용한다는 말은 정확히 소수 2번째 자리까지 출력하라는 뜻이 아니다.

예제 입력: 3             또는 3             또는 4                      또는 5               또는 2      또는 4                 또는 1   또는 9   

                 40 80 60          10 20 30         1 100 100 100         1 2 4 8 16         3 10         10 20 0 100         50         10 20 30 40 50 60 70 80 90

예제 출력:75.0                  66.666667      75.25                       38.75                65.0         32.5                     100,0   55.55555555555556           

풀이

const fs = require('fs');
const input = fs.readFileSync(0, "utf-8").trim().split("\n");

const N = Number(input[0]);
const score =input[1].split(' ').map(Number);
const max = Math.max(...score);

const newScores = score.map(num=>(num/max)*100);
const avg = newScores.reduce((acc,cur) => acc + cur , 0)/N;

console.log(avg);

풀이 해석

1. 입력값 처리

  - input[0]에는 과목 개수가 들어 있으므로, Number()로 변환한다.

  - input[1]을 공백 기준으로 나눈 후 .map(Number)로 숫자로 변환한다.

2. 최고 점수 찾기

  - score변수 배열에서 Math.max()를 사용하여 최고 점수를 찾는다.

  - 전개연산자(...)를 사용하여 배열의 값들을 나열한다.

3. 조정된 점수 계산

  - .map()을 사용해여 배열의 인덱스 마다 있는 기존 점수를 최고 점수로 나눈 후 100을 곱해 조정된 점수를 계산한다.

4. 새로운 평균 계산

  - reduce()를 사용하여 조정된 점수들의 합을 구한 후, 과목 개수N로 나누어 평균을 구한다.

5. 최종 결과 출력

  - console.log()에 새로운 평균을 출력한다.

 

더 알아보기

1. for반복문을 사용한 코드

const fs = require("fs");
const input = fs.readFileSync("/dev/stdin").toString().trim().split("\n");

const a = Number(input[0]);
const b = input[1].split(" ").map(Number);
const max = Math.max(...b);

let maxAverage = 0;

for (let i = 0; i < a; i++) {
  maxAverage += (b[i] / max) * 100;
}

console.log(parseFloat((maxAverage / a).toFixed(6)));

 

2. for반복문만 사용한 정답코드(Math.max() 사용X)

const fs = require('fs');
const input = fs.readFileSync(0, "utf-8").trim().split("\n");

const numSubjects = Number(input[0]); // 시험 과목 개수
const scores = input[1].split(' ').map(Number); // 점수를 숫자 배열로 변환

let maxScore = 0;

// 최고 점수 찾기 (`Math.max()` 없이 for문 사용)
for (let i = 0; i < numSubjects; i++) {
  if (scores[i] > maxScore) {
    maxScore = scores[i];
  }
}

// 조정된 점수 합 구하기 (`map()` 없이 for문 사용)
let adjustedSum = 0;
for (let i = 0; i < numSubjects; i++) {
  adjustedSum += (scores[i] / maxScore) * 100;
}

// 새로운 평균 계산
const newAverage = adjustedSum / numSubjects;

console.log(newAverage);