SMALL
문제 설명
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. 2016년 a월 b일과 2016년 1월 1일 간의 차를 구함
2. 일수를 7로 나눈 나머지를 n으로 저장
3. 금요일부터 목요일까지를 리스트에 저장
4. 요일 리스트[n]값을 출력
-> 금요일을 0 인덱스로 리스트에 저장했으므로 차이 일수를 7로 나눈 나머지가 0이면 금요일이 출력됨
-> 1인 경우 토, 2인 경우 일 ...
필요 함수 정리
날짜 차이
- date
- import : from datetime import date
- 형식 : date(년,월,일)
- 날짜를 표현하는데 사용
- date 객체간 빼기 가능
- .days로 일수만 추출
내 소스 코드
from datetime import date
def solution(a, b):
delta = date(2016,a,b) - date(2016,1,1)
week = ['FRI', 'SAT', 'SUN', 'MON', 'TUE', 'WED', 'THU']
n = delta.days % 7
return week[n]
결과
다른 사람 소스 코드
def solution(a, b):
months = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
days = ['FRI', 'SAT', 'SUN', 'MON', 'TUE', 'WED', 'THU']
return days[(sum(months[:a-1])+b-1)%7]
datetime 모듈을 사용하지 않은 풀이
months 리스트에 1월부터 12월까지의 일수를 넣음
days 리스트에는 금요일부터 목요일까지 넣음
리턴할 days 리스트의 인덱스는 [전 월까지의 일 수 합(a-1)과 현재 월의 일 수(b)를 더한 값을 7로 나눈 나머지]
'프로그래머스,백준 > 알고리즘' 카테고리의 다른 글
[이것이 코딩 테스트다 with Python] 백준 5585번 - 거스름돈 (Python) (0) | 2020.10.30 |
---|---|
[ 프로그래머스 ] LEVEL1 - 상위 n개 레코드 (Oracle,MySQL) (0) | 2020.10.29 |
[프로그래머스] Level1 - 문자열 내 p와 y의 개수 (Python) (0) | 2020.10.25 |
[프로그래머스] Level1 - 가운데 글자 가져오기 (Python) (0) | 2020.10.25 |
[프로그래머스] Level1 - 핸드폰 번호 가리기 (Python) (0) | 2020.10.25 |
댓글