[프로그래머스] Lv2. 최댓값과 최솟값

zzzzsb·2022년 2월 1일
0

프로그래머스

목록 보기
12/33

문제

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

문제 설명

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

제한사항

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

입출력 예

sreturn
"1 2 3 4""1 4"
"-1 -2 -3 -4""-4 -1"
"-1 -1""-1 -1"


Approach #1

brute force:
Input string 배열로 쪼개 넣고, 
for문 돌며 min,max 찾은뒤 리턴.

Solution #1

function solution(s) {
    const numArr= s.split(" ");
    //base case
    let max = Number(numArr[0]);
    let min = Number(numArr[0]);
    
    for(let i=1; i<numArr.length; i++){
        max = Math.max(max, Number(numArr[i]));
        min = Math.min(min, Number(numArr[i]));
    }
    return String(min)+" "+String(max);
}

N: s.length

Time Complexity

O(N)

Space Complexity

O(N)



Solution #2

function solution(s) {
    const arr = s.split(" ");

    return Math.min(...arr)+" "+Math.max(...arr);
}

N: s.length

Time Complexity

O(N)

Space Complexity

O(N)


Review

Math.min, Math.max 함수 사용할때 Number로 변환해서 해야하는 줄 알았더니, 문자열도 된다 ^.^;;
(자바스크립트만 되는듯 ^^;;)

TIL

  • spread(...) 연산자 활용해 배열요소를 분해하여 Math.min/max 함수에 넣으면, 배열 원소중 최대/최소값을 리턴한다.
profile
성장하는 developer

0개의 댓글