Algorithm/프로그래머스

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

햄습햄 2021. 11. 9. 14:18

문제 설명

 

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

 


풀이 과정 (자바)

 

String 형 answer와 int 형 배열 arr, int 형 i를 각각 생성했다.

arr은 1월부터 11월까지의 일수를 입력하기 위해 11 크기의 int 형 배열을 만들었다.

i에는 b 값을 넣었다.

 

arr는 매월 일수 값 - (1월: 31일 - 인덱스 0/ 2월: 29일 - 인덱스 1 ....)을 넣었다.

그리고 for 문을 돌려 i에 값을 더했다. 

 

그리고 switch을 이용해 i를 7로 나눴을 때의 나머지 값을 찾아 각각 해당하는 요일을 answer에 넣었다.

그 후, answer를 반환했다.

 

더보기

나머지 1이 금요일인 이유?

 

2016년 1월 1일은 금요일이다. (1%7 => 1)

2016년 1월 2일은 토요일이다. (2%7 => 2)

2016년 1월 3일은 일요일이다. (3%7 => 3)

2016년 1월 8일은 금요일이다. (8%7 => 1)

2016년 1월 15일은 금요일이다. (15%7 => 1)

 

총 일수에서 7로 나눈 나머지가 1일 때 금요일임을 알 수 있다.

(2016년 1월 1일을 1로 기준으로 본다.)



결과

 

 


다른 사람의 풀이

 

String 형 answer와 String 형 배열 day, int 형 배열 date를 각각 생성했다.

day는 FRI~THU까지 값을 넣었고, date은 1월부터 12월까지의 일수를 입력했다.

 

계산을 위해 int 형 allDate 변수를 생성했다.

for 문을 돌려 allDate에 date 값을 더했다.

 

for 문을 종료하고, 일수 b에서 1을 뺀 값을 allDate에 더했다.

allDate를 7로 나눈 나머지를 이용해 day 배열에서 값을 answer에 넣었다.

그리고 answer를 반환했다.

 

더보기

일수 b에서 1을 뺀 이유?

 

allDate를 7로 나눈 나머지를 이용해 day 배열에서 값을 넣어야 한다.

이때, 배열은 시작이 0부터이다.

 

그러므로 2016년 1월 1일 금요일일 때,

allDate % 7은 0 => day[0] => "FRI"가 된다.

 

추가로 예를 들어,

2016년 2월 13일 토요일이라고 한다.

allDate는 for 문을 통해 31이 된다.

 

for 문을 종료하고, 일수 13에서 1을 뺀 12를 allDate에 더하면

31 + 12 = 43

allDate는 43이 된다.

 

43 % 7 => 1이 되고, day[1]이 된다.

그러면 answer에는 "SAT"를 넣게 된다.

 

 

기타

 

생각해 보니 배열 값을 하나씩 입력할 게 아니라 한 번에 초기화해도 됐는데 왜 일일이 넣었는지 모르겠다. (아직 많이 부족한가 보다.) 매월 단위 일수뿐만 아니라 요일도 같이 배열로 만들어 한 번에 처리했다면 좀 더 간략하게 작성했을 거 같아 아쉬움이 남았다. 앞으로 더 나은 방법이 있는지 한 번 더 생각해 봐야겠다.