[백준 2948] 2009년 날짜 요일 구하기 (C#, C++) - soo:bak
작성일 :
문제 링크
설명
2009년의 특정 날짜가 무슨 요일인지 계산하는 문제입니다.
- 입력은
일(day)
과월(month)
로 주어집니다. - 2009년은 평년이므로 2월은
28일
까지 존재합니다. - 2009년 1월 1일은 목요일(Thursday)입니다.
접근법
- 먼저 각 월별 일수를 배열에 저장합니다. 2009년은 윤년이 아니므로 2월은 28일까지 존재합니다.
- 입력으로 주어진 날짜가 1월 1일로부터 며칠이 지났는지를 계산합니다.
- 예를 들어 3월 2일이라면, 1월과 2월의 일수(
31
+28
=59
일)에 3월의2
일을 더해 총61
일째가 됩니다. - 이때 시작 날짜인 1월 1일도 포함되므로 며칠이 지났는 지에 대해서는 하루를 빼서
(day - 1)
만큼 더해야 함에 주의합니다.
- 예를 들어 3월 2일이라면, 1월과 2월의 일수(
- 2009년 1월 1일은 목요일입니다. 요일 배열을
["Monday", "Tuesday", ..., "Sunday"]
로 설정했을 때,목요일
은3
번째 인덱스입니다. - 따라서
총 경과 일 수 + 3
을 계산한 뒤7
로 나눈 나머지를 통해 해당 요일의 인덱스를 구할 수 있습니다. - 해당 인덱스의 문자열을 출력하면 정답 요일이 됩니다.
Code
[ C# ]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
using System;
class Program {
static void Main() {
var input = Console.ReadLine().Split();
int day = int.Parse(input[0]);
int month = int.Parse(input[1]);
string[] weekdays = { "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday" };
int[] daysInMonth = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
int totalDays = 0;
for (int i = 0; i < month - 1; i++)
totalDays += daysInMonth[i];
totalDays += day - 1;
Console.WriteLine(weekdays[(totalDays + 3) % 7]);
}
}
[ C++ ]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
string weekdays[] = { "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday" };
int daysInMonth[] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
int day, month; cin >> day >> month;
int totalDays = 0;
for (int i = 0; i < month - 1; i++)
totalDays += daysInMonth[i];
totalDays += day - 1;
cout << weekdays[(totalDays + 3) % 7] << "\n";
return 0;
}