[백준] 1546. 평균(feat. Javascript / node.js) 알고리즘

준리·2022년 7월 1일
0

자료구조알고리즘

목록 보기
36/38
post-thumbnail
post-custom-banner

1차원 배열

: 평균 [1546]

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

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

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

예제 입력

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

3
40 80 60

예제 출력

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

75

제출


  //https://www.acmicpc.net/problem/1546

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

    const x = input[1].split(" ").map((v) => +v);
    
    const m = Math.max(...x);
    
    const newScore = x.map((item) => {
        return (item / m) * 100;
    });
    
    let sum = 0;
    
    for (let i = 0; i < newScore.length; i++) {
        sum += newScore[i];
    }
    console.log(sum / input[0]);


무엇을 해결해야 하는가?

입력 받은 값에서 실제로 사용할 배열을 x에 담고 숫자로 타입캐스팅을 했다.
거기서 Math.max를 활용하여 최댓값을 구하고
x를 map 함수를 사용해 문제의 배열을 만들었다.

그 배열을 더해 input[0] 값, 과목의 갯수를 나눠서 평균을 구했다.
오랜만에 하니까 다 까먹었다.
그래도 완성한게 좋다.

숏코딩

const [n, d] = require('fs').readFileSync(0, 'utf-8').trim().split('\n')
const d1 = d.split(' ').map(Number)
console.log(d1.reduce((a, b) => a + b)/Math.max(...d1)*100/n)

결국 같은 값을 직관적으로 짜는가에 대한 이야기이다.
비구조할당을 통해 처음 input 값을 나눠놓고,
그냥 reduce를 통해 더해서 나눠버리면 되는구나.
오늘도 배웠다.

profile
트렌디 풀스택 개발자
post-custom-banner

0개의 댓글