Bomb Kirby Running

코딩 테스트 챌린지

코딩 테스트 5

^. ̫ .^ 2023. 5. 22. 03:32

728x90

문제1 옷 가게 할인받기

머쓱이네 옷가게는 10만 원 이상 사면 5%, 30만 원 이상 사면 10%, 50만 원 이상 사면 20%를 할인해줍니다.
구매한 옷의 가격 price가 주어질 때, 지불해야 할 금액을 return 하도록 solution 함수를 완성해보세요.

 

제한사항

  • 10 ≤ price ≤ 1,000,000
  • price는 10원 단위로(1의 자리가 0) 주어집니다.
  • 소수점 이하를 버린 정수를 return합니다.

입출력 예

price result
150,000 142,500
580,000 464,000
function solution(price) {
    if(price >= 500000) {
        return Math.floor(price * 0.8);
    }
    if(price >= 300000) {
        return Math.floor(price * 0.9);
    }
    if(price >= 100000) {
        return Math.floor(price * 0.95);
    }
    return price;
}

if 문을 사용하여 각 조건들의 이상일 경우 price에 할인된 해당 가격(50만원 이상인 경우 30%할인이므로 80%의 가격 0.8)을 곱한 뒤 Math.floor로 소수점 이하를 버린 값을 return으로 반환해줍니다.

 

문제2 아이스 아메리카노

머쓱이는 추운 날에도 아이스 아메리카노만 마십니다. 아이스 아메리카노는 한잔에 5,500원입니다. 머쓱이가 가지고 있는 돈 money가 매개변수로 주어질 때, 머쓱이가 최대로 마실 수 있는 아메리카노의 잔 수와 남는 돈을 순서대로 담은 배열을 return 하도록 solution 함수를 완성해보세요.

제한사항

  • 0 < money ≤ 1,000,000

입출력 예

money result
5,500 [1, 0]
15,000 [2, 4000]
function solution(money) {
    const coffeeCnt = Math.floor(money / 5500);
    const moneyLeft = money % 5500
    return [coffeeCnt, moneyLeft];
}

머쓱이가 가지고 있는 돈에서 5500원을 나누면 살 수 있는 아메리카노의 잔 수를 구하고 Math.floor로 소수점은 버려줍니다. 그리고 나머지 돈은 %로 구해줍니다. 이 둘을 return으로 반환해줍니다.

 

문제3 나이 출력

머쓱이는 40살인 선생님이 몇 년도에 태어났는지 궁금해졌습니다. 나이 age가 주어질 때, 2022년을 기준 출생 연도를 return 하는 solution 함수를 완성해주세요.

 

제한사항

  • 0 < age ≤ 120
  • 나이는 태어난 연도에 1살이며 1년마다 1씩 증가합니다.

입출력 예

age result
40 1983
23 2000
function solution(age) {
    return 2022 - age + 1;
}

기준이 되는 2022년에서 나이 40이 있는 age를 빼면 1982가 나옵니다.

그런데 나이는 태어난 년도에 1살이므로 +1을 해주면 1983이 나옵니다.

 

문제4 배열 뒤집기

정수가 들어 있는 배열 num_list가 매개변수로 주어집니다. num_list의 원소의 순서를 거꾸로 뒤집은 배열을 return하도록 solution 함수를 완성해주세요

 

제한사항

  • 1 ≤ num_list의 길이 ≤ 1,000
  • 0 ≤ num_list의 원소 ≤ 1,000

입출력 예

num_list result
[1, 2, 3, 4, 5] [5, 4, 3, 2, 1]
[1, 1, 1, 1, 1, 2] [2, 1, 1, 1, 1, 1]
[1, 0, 1, 1, 1, 3, 5] [5, 3, 1, 1, 1, 0, 1]
function solution(num_list) {
    const newArray = [];
    let cnt = num_list.length - 1;
    while (cnt >= 0) {
        newArray.push(num_list[cnt]);
        
        cnt = cnt -1
    }
    return newArray;
}

새 배열을 만들고 cnt를 배열의 개수에 1을 빼도록 설정해주고 while문으로 0과 크거나 같을 때 num_list[cnt] 값을 newArray 배열에 추가합니다.

역순으로 요소를 추가하므로 num_list의 마지막 요소부터 시작하여 newArray에 차례로 추가됩니다

cnt 값을 1 감소시킵니다.

새로운 배열을 반환합니다.