본문 바로가기

알고리즘

[프로그래머스] 2016년 (python)

https://school.programmers.co.kr/learn/courses/30/lessons/12901 

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

📌 문제 설명

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"

🗒 풀이

def solution(a, b):
    days = ['FRI', 'SAT', 'SUN', 'MON', 'TUE', 'WED', 'THU']
    month = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
    return days[(sum(month[:a - 1]) + b) % 7 - 1]

일단 2016/1/1이 금요일이니, 금요일부터 시작한다고 보고 days를 금부터 지정한다.

month에는 1월부터 12월까지 각 달의 일 수를 넣어준다. 이때 2016년은 윤년이므로, 2월은 29일이다.

다음 입력받은 월의 전월까지 일 수를 합하고, 해당 월은 그 달의 일까지만 더해준다. 다음 7로 나누어 그 나머지로 요일을 찾는다.

이때 -1을 하는 이유는 1월 1일은 이미 계산했기 때문이다.