작성일 :

문제 링크

2948번 - 2009년

설명

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)만큼 더해야 함에 주의합니다.
  • 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;
}