728x90
문제 설명
2016년 1월 1일은 금요일입니다. 2016년 a월 b일은 무슨 요일일까요? 두 수 a ,b를 입력받아 2016년 a월 b일이 무슨 요일인지 리턴하는 함수, solution을 완성하세요. 요일의 이름은 일요일부터 토요일까지 각각 SUN,MON,TUE,WED,THU,FRI,SAT
입니다. 예를 들어 a=5, b=24라면 5월 24일은 화요일이므로 문자열 "TUE"를 반환하세요.
제한 조건
- 2016년은 윤년입니다.
- 2016년 a월 b일은 실제로 있는 날입니다. (13월 26일이나 2월 45일같은 날짜는 주어지지 않습니다)
입출력 예
a | b | result |
5 | 24 | "TUE" |
필요한 개념 .. (지식)
이 문제의 핵심은 매달이 몇 일로 이루어져있는지 인 것 같다...
누가 그걸 모르냐고,,,? 내가 몰랐다. ㅎ
이젠 아니까 똑똑한 사람 ~ ..

1월: 31일
2월:28/29일
3월:31일
4월:30일
5월:31일
6월:30일
7월:31일
8월:31일
9월:30일
10월:31일
11월:30일
12월:31일
문제에서 제시한 '윤년'에는 2월달에 29일까지 있다. 즉, 4년 마다 (1996, 2000, 2004, 2008, 2012, 2016, 2020 ...) 윤년이 온다.
이를 참고해서
String[] day= {"FRI", "SAT", "SUN", "MON", "TUE", "WED", "THU"};
int[] date = {31, 29,31,30,31, 30, 31, 31, 30, 31, 30,31};
요일을 담은 String 배열과 몇 일이 한 달에 있는지를 담은 int 배열을 만든다.
+) String 배열에서 금요일 부터 시작한 것은 1월 1일이 금요일 이였기 때문이다.
class Solution {
public String solution(int a, int b) {
String answer = "";
int days =0;
String[] day= {"FRI", "SAT", "SUN", "MON", "TUE", "WED", "THU"};
int[] date = {31, 29,31,30,31, 30, 31, 31, 30, 31, 30,31};
for(int i = 0; i< a-1; i++)
{
days += date[i];
}
days += (b-1);
answer = day[days%7];
return answer;
}
}
<알고리즘 설명>
1. a월 b일 까지의 모든 일수를 더해준다.
- b - 1을 더하는 이유는 1월 1일을 빼는 것이다. 인덱스가 0부터인 것을 잊지말자.
2. 모든 일수를 더해준 변수를 7로 나눠서 나온 인덱스의 요일을 추출
728x90
'Coding Test > 프로그래머스' 카테고리의 다른 글
[프로그래머스] Lv.1 옹알이(2) (1) | 2024.02.29 |
---|---|
[프로그래머스] Lv.1 모의고사 (0) | 2024.02.27 |
[프로그래머스] Lv.1 [1차]비밀지도 (1) | 2024.02.26 |
[프로그래머스] Lv.1 두 개 뽑아서 더하기 (1) | 2024.02.26 |
[프로그래머스] Lv.1 K번째수 (0) | 2024.02.25 |