N개의 정수가 주어진다. 이때, 최솟값과 최댓값을 구하는 프로그램을 작성하시오.
첫째 줄에 정수의 개수 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 N개의 정수를 공백으로 구분해서 주어진다. 모든 정수는 -1,000,000보다 크거나 같고, 1,000,000보다 작거나 같은 정수이다.
첫째 줄에 주어진 정수 N개의 최솟값과 최댓값을 공백으로 구분해 출력한다.
5
20 10 35 30 7
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}`);
백준 문제를 풀다보면 문제 자체를 푸는 것보다, 문제를 풀기 위한 상황을 세팅하는 것이 더 어려울 때가 있다. 예를 들어 이번 문제처럼 입력 값을 최대, 최소를 구하는 알고리즘은 그다지 어렵지 않지만 입력 값을 받아올 때 어떤 방식으로 알고리즘을 짜느냐를 더 고민하게 된다.
위 문제는 입력 값 전체('\n' 포함)를 배열로 받아와서, split 메서드를 사용하여 '\n'을 기준으로 입력 받을 총 수의 개수를 따로 분리하고, 나머지 배열에서 입력 값을 split 메서드를 사용하여 ' '를 기준으로 분리하였고, 해당 배열을 map 메서드를 사용하여 number 타입으로 바꾸어주었다. 이런 식으로 'data set'이랄까.. 결과를 출력하기 위한 준비물들을 만들었다.