“ 당신이 6개월 이상 한 번도 보지 않은 코드는 다른 사람이 다시 만드는 게 훨씬 더 나을 수 있다. ”
코딩테스트 입문 Day 5 수학, 배열
출처 : https://programmers.co.kr/
옷가게 할인 받기
문제
머쓱이네 옷가게는 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 |
입출력 예 설명
입출력 예 #1
- 150,000원에서 5%를 할인한 142,500원을 return 합니다.
입출력 예 #2
- 580,000원에서 20%를 할인한 464,000원을 return 합니다.
solution.js
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 >= 500000) { ... }: 만약 가격(price)이 500,000 이상이면 조건을 만족합니다. 이 경우, 가격의 80%에 해당하는 값을 계산하여 내림(floor)하여 반환합니다. 즉, 20% 할인이 적용됩니다.
- if(price >= 300000) { ... }: 가격이 300,000 이상인 경우 조건을 만족합니다. 이 경우, 가격의 90%에 해당하는 값을 계산하여 내림(floor)하여 반환합니다. 즉, 10% 할인이 적용됩니다.
- if(price >= 100000) { ... }: 가격이 100,000 이상인 경우 조건을 만족합니다. 이 경우, 가격의 95%에 해당하는 값을 계산하여 내림(floor)하여 반환합니다. 즉, 5% 할인이 적용됩니다.
- return price;: 위의 조건들을 모두 만족하지 않는 경우, 가격을 그대로 반환합니다.
아이스 아메리카노
문제
머쓱이는 추운 날에도 아이스 아메리카노만 마십니다. 아이스 아메리카노는 한잔에 5,500원입니다. 머쓱이가 가지고 있는 돈 money가 매개변수로 주어질 때, 머쓱이가 최대로 마실 수 있는 아메리카노의 잔 수와 남는 돈을 순서대로 담은 배열을 return 하도록 solution 함수를 완성해보세요.
제한사항
- 0 < money ≤ 1,000,000
입출력 예
money | result |
5,500 | [1,0] |
15,000 | [2,4000] |
입출력 예 설명
입출력 예 #1
- 5,500원은 아이스 아메리카노 한 잔을 살 수 있고 잔돈은 0원입니다.
입출력 예 #2
- 15,000원은 아이스 아메리카노 두 잔을 살 수 있고 잔돈은 4,000원입니다.
solution.js
function solution(money) {
var answer = [Math.floor(money / 5500), money % 5500];
return answer;
}
- Math.floor(money / 5500): 주어진 금액을 5500으로 나눈 몫을 계산합니다. 이는 주어진 금액으로 가능한 최대 상품 수량을 의미합니다. Math.floor() 함수를 사용하여 소수점 이하를 버립니다.
- money % 5500: 주어진 금액을 5500으로 나눈 나머지를 계산합니다. 이는 최대 수량으로 구매한 후에 남은 금액을 의미합니다.
- [Math.floor(money / 5500), money % 5500]: 계산된 최대 수량과 남은 금액을 배열로 묶어서 저장합니다.
- return answer;: 배열 answer를 반환합니다.
나이 출력
문제
머쓱이는 40살인 선생님이 몇 년도에 태어났는지 궁금해졌습니다. 나이 age가 주어질 때, 2022년을 기준 출생 연도를 return 하는 solution 함수를 완성해주세요.
제한사항
- 0 < age ≤ 120
- 나이는 태어난 연도에 1살이며 1년마다 1씩 증가합니다.
입출력 예
age | result |
40 | 1983 |
23 | 2000 |
입출력 예 설명
입출력 예 #1
- 2022년 기준 40살이므로 1983년생입니다.
입출력 예 #2
- 2022년 기준 23살이므로 2000년생입니다.
solution.js
function solution(age) {
var answer = 2022 - age + 1;
return answer;
}
- 2022 - age + 1: 2022년을 기준으로 현재 나이를 계산하기 위해, 2022에서 주어진 나이를 뺀 후 1을 더합니다. 이를 통해 2022년에 해당하는 나이를 계산합니다.
- var answer = 2022 - age + 1;: 계산된 나이를 변수 answer에 저장합니다.
- return answer;: 계산된 값을 반환합니다.
배열 뒤집기
문제
정수가 들어 있는 배열 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] |
입출력 예 설명
입출력 예 #1
- num_list가 [1, 2, 3, 4, 5]이므로 순서를 거꾸로 뒤집은 배열 [5, 4, 3, 2, 1]을 return합니다.
입출력 예 #2
- num_list가 [1, 1, 1, 1, 1, 2]이므로 순서를 거꾸로 뒤집은 배열 [2, 1, 1, 1, 1, 1]을 return합니다.
입출력 예 #3
- num_list가 [1, 0, 1, 1, 1, 3, 5]이므로 순서를 거꾸로 뒤집은 배열 [5, 3, 1, 1, 1, 0, 1]을 return합니다.
solution.js
function solution(num_list) {
const newArray = [];
const length = num_list.length;
for (let i = length - 1; i >= 0; i--) {
newArray.push(num_list[i]);
}
return newArray;
}
- const newArray = [];: 새로운 배열을 빈 배열로 초기화합니다.
- const length = num_list.length;: 주어진 배열의 길이를 변수 length에 저장합니다.
- for (let i = length - 1; i >= 0; i--) { ... }: 주어진 배열의 마지막 인덱스부터 시작하여 처음 인덱스까지 반복하는 반복문입니다.
- newArray.push(num_list[i]);: 현재 인덱스의 요소를 새로운 배열에 추가합니다. 이를 통해 원래 배열의 요소를 역순으로 새로운 배열에 저장합니다.
- return newArray;: 역순으로 정렬된 요소가 저장된 새로운 배열을 반환합니다.