Patrick's Devlog

[BOJ/C++] 2007년(1924번) 본문

Study/Algorithms Practice

[BOJ/C++] 2007년(1924번)

Patrick_ 2022. 5. 10. 14:33

1. 문제 개요

https://www.acmicpc.net/problem/1924

 

1924번: 2007년

첫째 줄에 빈 칸을 사이에 두고 x(1 ≤ x ≤ 12)와 y(1 ≤ y ≤ 31)이 주어진다. 참고로 2007년에는 1, 3, 5, 7, 8, 10, 12월은 31일까지, 4, 6, 9, 11월은 30일까지, 2월은 28일까지 있다.

www.acmicpc.net

1-1. 설명

오늘은 2007년 1월 1일 월요일이다. 그렇다면 2007년 x월 y일은 무슨요일일까? 이를 알아내는 프로그램을 작성하시오

 

1-2. 제한사항

 - x월 y일을 입력받음

 - x는 1이상 12이하, y는 1이상 31이하

 - 2월은 28일까지 존재


2. 구현

2-1. 풀이

단순하게 요일과 달마다 일 수를 vector로 저장하고 x월 y일을 입력받아 일의 수를 합산하고 마지막에 7로 나눈 나머지를 구한다.

 

2-2. 코드

#include <iostream>
#include <vector>
using namespace std;

int main() {
	vector<string> week = { "SUN", "MON","TUE","WED","THU","FRI","SAT"};
	vector<int> months = { 31,28,31,30,31,30,31,31,30,31,30,31 };
	int month, day;

	cin >> month >> day;
	for (int i = 0; i < month-1; i++) day += months[i];
	cout << week[day % 7] << endl;
}