[백준/Node.js] 10818번: 최소, 최대

Jay Kim·2020년 4월 5일
0

제한 사항


문제

N개의 정수가 주어진다. 이때, 최솟값과 최댓값을 구하는 프로그램을 작성하시오.


입력

첫째 줄에 정수의 개수 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 N개의 정수를 공백으로 구분해서 주어진다. 모든 정수는 -1,000,000보다 크거나 같고, 1,000,000보다 작거나 같은 정수이다.


출력

첫째 줄에 주어진 정수 N개의 최솟값과 최댓값을 공백으로 구분해 출력한다.


예제 입력 1

5
20 10 35 30 7

예제 출력 1

7 35

소스 코드

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

let count = Number(input[0]);
let numberStr = input[1].split(' ');

let numbers = numberStr.map(function(cur) {
  return Number(cur);
});

let max = numbers[0];
let min = numbers[0];
for (let i = 1; i < count; i++) {
  if (max < numbers[i]) {
    max = numbers[i];
  }
  if (min > numbers[i]) {
    min = numbers[i];
  }
}
console.log(`${min} ${max}`);

Comment

백준 문제를 풀다보면 문제 자체를 푸는 것보다, 문제를 풀기 위한 상황을 세팅하는 것이 더 어려울 때가 있다. 예를 들어 이번 문제처럼 입력 값을 최대, 최소를 구하는 알고리즘은 그다지 어렵지 않지만 입력 값을 받아올 때 어떤 방식으로 알고리즘을 짜느냐를 더 고민하게 된다.
위 문제는 입력 값 전체('\n' 포함)를 배열로 받아와서, split 메서드를 사용하여 '\n'을 기준으로 입력 받을 총 수의 개수를 따로 분리하고, 나머지 배열에서 입력 값을 split 메서드를 사용하여 ' '를 기준으로 분리하였고, 해당 배열을 map 메서드를 사용하여 number 타입으로 바꾸어주었다. 이런 식으로 'data set'이랄까.. 결과를 출력하기 위한 준비물들을 만들었다.


Reference

profile
minuzai

0개의 댓글