結果
| 問題 |
No.87 Advent Calendar Problem
|
| コンテスト | |
| ユーザー |
bluemegane
|
| 提出日時 | 2021-05-10 19:26:54 |
| 言語 | C#(csc) (csc 3.9.0) |
| 結果 |
AC
|
| 実行時間 | 22 ms / 5,000 ms |
| コード長 | 1,075 bytes |
| コンパイル時間 | 3,361 ms |
| コンパイル使用メモリ | 110,852 KB |
| 実行使用メモリ | 25,688 KB |
| 最終ジャッジ日時 | 2024-09-19 23:32:32 |
| 合計ジャッジ時間 | 4,943 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 24 |
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc) Copyright (C) Microsoft Corporation. All rights reserved.
ソースコード
using System;
public class Hello
{
static void Main()
{
var t = 0;
for (int i = 2000; i <= 2014; i++) t += check(i);
var t2014 = t % 7;
var n = long.Parse(Console.ReadLine().Trim());
if (n <= 2399) Console.WriteLine(calcDays(2015, (int)n, t2014, t2014));
else
{
long ans = calcDays(2015, 2399, t2014, t2014);
var box = calcDays(2000, 2399, t2014);
ans += (n / 400L - 2014 / 400L - 1) * box;
ans += calcDays((n / 400L) * 400L, n, t2014);
Console.WriteLine(ans);
}
}
static int calcDays(long from, long to, int t2014, int start = 0)
{
var res = 0;
var t = start;
for (long i = from; i <= to; i++)
{
t += check(i);
t %= 7;
if (t == t2014) res++;
}
return res;
}
static int check(long y)
{
if (y % 400 == 0) return 2;
else if (y % 100 == 0) return 1;
else if (y % 4 == 0) return 2;
else return 1;
}
}
bluemegane