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 |
- 150,000원에서 5%를 할인한 142,500원을 return 합니다.
- 580,000원에서 20%를 할인한 464,000원을 return 합니다.
💻 나의 풀이
class Solution {
public int solution(int price) {
if (price >= 500000) {
price *= 0.8;
} else if (price >= 300000) {
price *= 0.9;
} else if (price >= 100000) {
price *= 0.95;
}
return price;
}
}
🔎 다른 사람의 풀이
class Solution {
public int solution(int price) {
int answer = 0;
if(price>=500000) return (int)(price*0.8);
if(price>=300000) return (int)(price*0.9);
if(price>=100000) return (int)(price*0.95);
return price;
}
}
2️⃣ 아이스 아메리카노
문제 설명
머쓱이는 추운 날에도 아이스 아메리카노만 마십니다. 아이스 아메리카노는 한잔에 5,500원입니다. 머쓱이가 가지고 있는 돈 money가 매개변수로 주어질 때, 머쓱이가 최대로 마실 수 있는 아메리카노의 잔 수와 남는 돈을 순서대로 담은 배열을 return 하도록 solution 함수를 완성해보세요.
제한사항
- 0 < money ≤ 1,000,000
입출력 예
money | result |
5,500 | [1, 0] |
15,000 | [2,4000] |
💻 나의 풀이
class Solution {
public int[] solution(int money) {
return new int[] {money/5500, money%5500};
}
}
가지고있는 돈을 5500원으로 나누면 몫이 커피의 갯수가 될거고, 나머지는 잔돈이 됩니다.
3️⃣ 나이 출력
문제 설명
머쓱이는 40살인 선생님이 몇 년도에 태어났는지 궁금해졌습니다. 나이 age가 주어질 때, 2022년을 기준 출생 연도를 return 하는 solution 함수를 완성해주세요.
제한사항
- 0 < age ≤ 120
- 나이는 태어난 연도에 1살이며 1년마다 1씩 증가합니다.
입출력 예
age | result |
40 | 1983 |
23 | 2000 |
💻 나의 풀이
class Solution {
public int solution(int age) {
return 2022-age+1; // 태어난 연도에 1살이니까 +1
}
}
현재연도에서 나이를 뺴준 후, 태어난 연도에 1살이니까 +1을 해줍니다.
🔎 다른 사람의 풀이
import java.time.*;
class Solution {
public int solution(int age) {
LocalDate today = LocalDate.now();
return today.getYear() - age + 1;
}
}
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] |
💻 나의 풀이
class Solution {
public int[] solution(int[] num_list) {
int[] answer = new int[num_list.length]; //num_list 배열의 크기만큼 answer 배열 생성
for(int i=0; i<num_list.length; i++){
answer[num_list.length-i-1] = num_list[i]; //num_list의 값들을 반대되는 순서로 넣어줌. 인덱스는 0부터 시작해 배열의 크기보다 1작기 때문에 -1 해줌.
}
return answer;
}
}
🔎 다른 사람의 풀이
import java.util.Collections;
import java.util.List;
import java.util.stream.Collectors;
import java.util.Arrays;
class Solution {
public int[] solution(int[] numList) {
List<Integer> list = Arrays.stream(numList).boxed().collect(Collectors.toList());
Collections.reverse(list);
return list.stream().mapToInt(Integer::intValue).toArray();
}
}
'프로그래머스 > 0단계' 카테고리의 다른 글
DAY7 문자열, 조건문, 수학, 반복문 (1) | 2023.11.24 |
---|---|
DAY6 문자열, 반복문, 출력, 배열, 조건문 (1) | 2023.11.23 |
DAY4 수학, 배열 (0) | 2023.11.22 |
DAY3 사칙연산, 배열, 수학 (0) | 2023.11.22 |
DAY2 사칙연산, 조건문, 배열 (1) | 2023.11.21 |