본문 바로가기
코딩 문제/프로그래머스 [ JavaScript ]

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

by CODESIGN 2022. 9. 20.

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"

 

 

나의 풀이


string인 s를 split(" ") 해준 뒤, Number로 형 변환을 시켜준 뒤 오름차순으로 정렬시켰다.

이렇게 하면 제일 작은 수가 첫 번째로 그리고 제일 큰 수가 마지막에 오게 돼서

처음과 마지막 값을 출력해 주었다.

 

function solution(s) {
    var answer = s.split(" ").map(Number).sort((a,b) => a-b);
    return answer[0] + " " + answer[answer.length-1];
}

 

 

 

다른 풀이


내가 푼 방법보다 코드도 간결하고 효율적이다.

 

입력받은 s의 string을 split(" ")을 해줘 배열로 변환한 뒤

Math.min()으로 최솟값과 Math.max()로 최댓값을 구하였다.

 

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

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

 

 

 

댓글