zoukankan      html  css  js  c++  java
  • 蓝桥杯 黑色星期五 基姆拉尔森公式

    问题描述
      有些西方人比较迷信,如果某个月的13号正好是星期五,他们就会觉得不太吉利,用古人的说法,就是“诸事不宜”。请你编写一个程序,统计出在某个特定的年份中,出现了多少次既是13号又是星期五的情形,以帮助你的迷信朋友解决难题。
      说明:(1)一年有365天,闰年有366天,所谓闰年,即能被4整除且不能被100整除的年份,或是既能被100整除也能被400整除的年份;(2)已知1998年1月1日是星期四,用户输入的年份肯定大于或等于1998年。
      输入格式:输入只有一行,即某个特定的年份(大于或等于1998年)。
      输出格式:输出只有一行,即在这一年中,出现了多少次既是13号又是星期五的情形。
    输入输出样例
    样例输入
    1998
    样例输出
    3
    基姆拉尔森公式计算星期的简单运用,把公式背下来就好办了。
     1 #include <bits/stdc++.h>
     2 using namespace std;
     3 int calweek(int y, int m, int d){
     4     if (m == 1 || m == 2){
     5         m += 12;
     6         y--;
     7     }
     8     return (d + 2 * m + 3 * (m + 1) / 5 + y + y / 4 - y / 100 + y / 400) % 7 + 1;
     9 }
    10 int main() {
    11     int y, m, d;
    12     cin >> y;
    13     d = 13;
    14     int ans = 0;
    15     for (int i = 1; i <= 12; i++) {
    16         m = i;
    17         int week = calweek(y, m, d);
    18         if (week == 5){
    19             ans++;
    20         }
    21     } 
    22     cout << ans << endl;
    23     return 0;
    24 }
  • 相关阅读:
    cmake使用总结
    Fatal error RC1015: cannot open include file "xxxx.h" vs2008
    可重入函数(转)
    《左耳听风》-ARTS-打卡记录-第十二周
    异常声明
    QString与const char *相互转换
    Qt中使用子线程去关闭弹出框
    什么是反向代理
    【GOJ 3002】颜色
    【GOJ 2296】毛毛虫
  • 原文地址:https://www.cnblogs.com/fx1998/p/12673238.html
Copyright © 2011-2022 走看看