[프로그래머스] Lv1. 2016년

2 분 소요

문제

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일같은 날짜는 주어지지 않습니다)

나의 풀이:

def solution(a, b):
    날짜수 = 1 1일부터 a월 b일까지의  날짜수
				if 날짜수 % 7 == 0:
				    return "THU"
				elif 날짜수 % 7 == 1:
				    return "FRI"
				elif 날짜수 % 7 == 2:
				    return "SAT"
				elif 날짜수 % 7 == 3:
				    return "SUN"
				elif 날짜수 % 7 == 4:
				    return "MON"
				elif 날짜수 % 7 == 5:
				    return "TUE"
				elif 날짜수 % 7 == 6:
				    return "WED"

문제를 pseudo 코드로 풀어보면 위와 같을 것이다. 날짜수의 계산이 관건이다.

def solution(a, b):
		 날짜수 =
		a가 1월이면 b 만으로 가능
		a가 2월이면 31 + b
		a가 3월이면 31 + 29 + b
		a가 4월이면 31 + 29 + 31 + b
		a가 5월이면 31 + 29 + 31 + 30 + b
		a가 6월이면 31 + 29 + 31 + 30 + 31 + b
		a가 7월이면 31 + 29 + 31 + 30 + 31 + 30 + b
		a가 8월이면 31 + 29 + 31 + 30 + 31 + 30 + 31 + b
		a가 9월이면 31 + 29 + 31 + 30 + 31 + 30 + 31 + 31 + b
		a가 10월이면 31 + 29 + 31 + 30 + 31 + 30 + 31 + 31 + 30 + b
		a가 11월이면 31 + 29 + 31 + 30 + 31 + 30 + 31 + 31 + 30 + 31 + b
		a가 12월이면 31 + 29 + 31 + 30 + 31 + 30 + 31 + 31 + 30 + 31 + 30 + b
		
		if 날짜수 % 7 == 0:
		    return "THU"
		elif 날짜수 % 7 == 1:
		    return "FRI"
		elif 날짜수 % 7 == 2:
		    return "SAT"
		elif 날짜수 % 7 == 3:
		    return "SUN"
		elif 날짜수 % 7 == 4:
		    return "MON"
		elif 날짜수 % 7 == 5:
		    return "TUE"
		elif 날짜수 % 7 == 6:
		    return "WED

위 과정을 잘 정리하면 되지 않을까?

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

달 별로의 요일수와 요일의 종류는 항상 반복되기 때문에 리스트로 계산하면 쉬울 것이라고 생각했다. 인덱스 슬라이싱을 통해 월별로 지나간 요일수의 합을 구하고, if문 대신 “날짜수 % 7”의 값을 곧바로 리스트 인덱스로 사용할 수 있도록 했다.

다른 사람들의 풀이:

def solution(a,b):
    answer = ""
    if a>=2:
        b+=31
        if a>=3:
            b+=29#2월
            if a>=4:
                b+=31#3월
                if a>=5:
                    b+=30#4월
                    if a>=6:
                        b+=31#5월
                        if a>=7:
                            b+=30#6월
                            if a>=8:
                                b+=31#7월
                                if a>=9:
                                    b+=31#8월
                                    if a>=10:
                                        b+=30#9월
                                        if a>=11:
                                            b+=31#10월
                                            if a==12:
                                                b+=30#11월
    b=b%7

    if b==1:answer="FRI"
    elif b==2:answer="SAT" 
    elif b==3:answer="SUN"
    elif b==4:answer="MON"
    elif b==5:answer="TUE"
    elif b==6:answer="WED"
    else:answer="THU"
    return answer

노가다를 예술로 승화시켰다는 작품ㅋㅋㅋㅋㅋ

하지만 웃지말자, 나도 리스트 생각 못했으면 저리할 뻔 했으니…

댓글남기기