알고리즘

[프로그래머스 level2] 최댓값과 최솟값 | JavaScript

작은코딩 2023. 7. 14. 14:47

🔒 문제

https://school.programmers.co.kr/learn/courses/30/lessons/12939

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

최댓값과 최솟값


문제 설명
문자열 s에는 공백으로 구분된 숫자들이 저장되어 있습니다. str에 나타나는 숫자 중 최소값과 최대값을 찾아 이를 "(최소값) (최대값)"형태의 문자열을 반환하는 함수, solution을 완성하세요.
예를들어 s가 "1 2 3 4"라면 "1 4"를 리턴하고, "-1 -2 -3 -4"라면 "-4 -1"을 리턴하면 됩니다.

제한 조건
s에는 둘 이상의 정수가 공백으로 구분되어 있습니다.


입출력 예

s return
"1 2 3 4"  "1 4"
"-1 -2 -3 -4"  "-4 -1"
"-1 -1"  "-1 -1"

 


🔑 풀이

function solution(s) {
    let maxN
    let minN
    
    const numList = s.split(' ').map((v) => Number(v))
    maxN = numList[0]
    minN = numList[0]

    for (let i = 1; i < numList.length; i++) {
        if (maxN < numList[i]) {
            maxN = numList[i]
        }
        if (minN > numList[i]) {
            minN = numList[i]
        }
    }
    return `${minN} ${maxN}`
}

 


💉 피드백

자바스크립트 내장 객체 Math의 min, max 함수를 사요하면 더 간단히 해결할 수 있고 그렇게 만들어진 코드가 가독성이 떨어지지도 않는다. 

 

function solution(s) {
    const arr = s.split(' ')

    return `${Math.min(...arr)} ${Math.max(...arr)}`
}