본문 바로가기
프로그래밍/백준 알고리즘

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

by 정빈e 2021. 7. 29.
728x90

출처: 백준

 

10818번: 최소, 최대

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

www.acmicpc.net

문제

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

내 코드

const readline = require("readline");
const rl = readline.createInterface({
    input : process.stdin,
    output : process.stdout
});

let input = [];

rl.on("line", function(line){
    input.push(line.split(' ').map(Number));
}).on("close", function(){
    let n = input[0]; // 입력받을 n개의 수
    let numbers = [];

    for(let i=0; i<n; i++){ // n번 입력받을 수를 numbers에 push
        numbers.push(input[1][i]);
    }

    let max = numbers[0];   // numbers의 첫 번째 수를  max, min에 할당
    let min = numbers[0];

    for(let i=1; i<numbers.length; i++){  // numbers의 두 번째 수부터 비교
        if(max < numbers[i]) max = numbers[i];
        else if(min > numbers[i]) min = numbers[i];
    }

    console.log(min, max);
    process.exit();
})

결과

> 5
20 10 35 30 7
7 35

입력받은 수의 첫 번째 수를 기준으로 다음 수들과 비교해서 최댓값과 최솟값을 구해보았다.

 

 

 

 

 

728x90

댓글