문제링크
https://www.acmicpc.net/problem/1924
문제
오늘은 2007년 1월 1일 월요일이다. 그렇다면 2007년 x월 y일은 무슨 요일일까? 이를 알아내는 프로그램을 작성하시오.
입력
첫째 줄에 빈 칸을 사이에 두고 x(1 ≤ x ≤ 12)와 y(1 ≤ y ≤ 31)이 주어진다. 참고로 2007년에는 1, 3, 5, 7, 8, 10, 12월은 31일까지, 4, 6, 9, 11월은 30일까지, 2월은 28일까지 있다.
출력
첫째 줄에 x월 y일이 무슨 요일인지에 따라 SUN, MON, TUE, WED, THU, FRI, SAT중 하나를 출력한다.
해석
1월 1일부터 지난 날짜를 모두 '일'로 바꾸고 7로 mod연산을 해준다.
코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
#include <iostream>
using namespace std;
int months[] = {0, 31,28,31,30,31,30,31,31,30,31,30,31 };
string days[] = {"SUN", "MON", "TUE", "WED", "THU", "FRI", "SAT" };
int main() {
int day = 0;
int x, y;
cin >> x >> y;
for (int i = 1; i <= x - 1; i++) {
day = day + months[i];
}
day = day + y;
day = (day % 7);
cout << days[day];
}
|
cs |
Memo
이전에 윤달문제로 풀었던 문제가 도움이 많이 되었다.