프로그래머스 Level 1 - 2016
Algorithm/Programers Level 1

프로그래머스 Level 1 - 2016

반응형

문제

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

My Sol

import time
def solution(a, b):
    start = time.time()
    answer = ''
    numOfday = [31,29,31,30,31,30,31,31,30,31,30,31]
    dayOfweek = ["THU", "FRI", "SAT", "SUN", "MON", "TUE", "WED"]
    day_count = 0
    
    for i in range(a-1):
        day_count += numOfday[i]
    day_count += b
    
    answer = dayOfweek[day_count % len(dayOfweek)]
    
    return answer

 

Best Sol

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

 

 

설명

My Sol 수행 시간 : 2.23초

Best Sol 수행 시간 : 1.19초

반복문으로 인한 수행시간 지연 예상

반응형