작성일 :

문제 링크

3183번 - Dates

설명

입력된 날짜가 실제로 존재하는지 판별하는 문제입니다.


접근법

월이 1~12 범위인지 확인하고, 윤년 규칙에 따라 2월 일수를 결정합니다.

이후 각 월의 최대 일수를 넘는지 검사해 유효 여부를 출력합니다.


Code

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
25
26
27
28
29
using System;

class Program {
  static bool IsLeap(int y) {
    if (y % 400 == 0) return true;
    if (y % 100 == 0) return false;
    return y % 4 == 0;
  }

  static void Main() {
    while (true) {
      var parts = Console.ReadLine()!.Split();
      var d = int.Parse(parts[0]);
      var m = int.Parse(parts[1]);
      var y = int.Parse(parts[2]);
      if (d == 0 && m == 0 && y == 0) break;

      if (m < 1 || m > 12) {
        Console.WriteLine("Invalid");
        continue;
      }

      var days = new[] { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
      if (IsLeap(y)) days[1] = 29;

      Console.WriteLine(d >= 1 && d <= days[m - 1] ? "Valid" : "Invalid");
    }
  }
}

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
25
26
27
28
29
30
#include <bits/stdc++.h>
using namespace std;

bool isLeap(int y) {
  if (y % 400 == 0) return true;
  if (y % 100 == 0) return false;
  return y % 4 == 0;
}

int main() {
  ios::sync_with_stdio(false);
  cin.tie(nullptr);

  while (true) {
    int d, m, y; cin >> d >> m >> y;
    if (d == 0 && m == 0 && y == 0) break;

    if (m < 1 || m > 12) {
      cout << "Invalid\n";
      continue;
    }

    int days[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
    if (isLeap(y)) days[1] = 29;

    cout << (d >= 1 && d <= days[m - 1] ? "Valid" : "Invalid") << "\n";
  }

  return 0;
}