본문 바로가기
프로그래머스,백준/알고리즘

[프로그래머스] Level1 - 2016년 (Python)

by z.1nee 2020. 10. 25.
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로 나눈 나머지]

 

 

 

댓글