算法题每日一练---第28天:世纪末的星期

简介: 曾有邪教称 1999 年 12 月 31 日是世界末日。当然该谣言已经不攻自破。

一、问题描述


曾有邪教称 1999 年 12 月 31 日是世界末日。当然该谣言已经不攻自破。


还有人称今后的某个世纪末的 12 月 31 日,如果是星期一则会....

有趣的是,任何一个世纪末的年份的 12 月 31 日都不可能是星期一 !!


于是,“谣言制造商”又修改为星期日......

1999 年的 12 月 31 日是星期五,请问:未来哪一个离我们最近的一个世纪末年(即 xx99 年)的 12 月 31 日正好是星期天(即星期日)?


二、题目要求


考察

日期问题、数学思想
建议用时15~25min


三、问题分析


这一题是一个日期问题,题目给出1999 年的 12 月 31 日是星期五,求出接下来最近的世纪末年。分成两步解决,先求出每一个年份的天数,在求出当前年份的最后一天是不是星期天。


1.判断年份

对于年份来说,首先判断是不是闰年,根据闰年规则“四年一闰,百年不闰,四百年一闰”,年份满足下列条件之一,则为闰年。

(1)能被4整除且不能被100整除(如2004年是闰年,而1900年不是)

(2)能被400整除(如2000年是闰年)

代码实现y%400==0||y%4==0&&y%100!=0


2.判断日期

q=(q+d%7)%7;//判断当前年份最后一天星期几if(q==0&&n%100==99)//满足条件{
cout<<n;//输出结果exit(0);//退出循环}


四、编码实现


#include<iostream>usingnamespacestd;
intmain()
{
inti,n,d,q=5;//初始化,d代表当前年份天数,q代表星期几for(i=2000;;i++)//开始循环    {
n=i;
if(n%400==0||n%4==0&&n%100!=0)//判断是否为闰年        {
d=366;
        }
elsed=365;
q=(q+d%7)%7;//判断当前年份最后一天星期几if(q==0&&n%100==99)//满足条件        {
cout<<n;//输出结果exit(0);//退出循环        }
    }
return0;
}


五、输出结果


输出结果为:2299

相关文章
|
6天前
|
算法 Java 程序员
【算法每日一练及解题思路】有n级台阶,一次只能上1级或2级,共有多少种走法?
本文深入解析了“爬楼梯问题”,探讨了递归与迭代两种解法,并提供了Java代码实现。通过分析问题本质,帮助读者理解动态规划技巧,提高解决实际编程问题的能力。关键词:Java, 算法, 动态规划, 爬楼梯问题, 递归, 迭代。
17 0
|
算法
算法题每日一练---第78天:二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target
186 1
算法题每日一练---第78天:二分查找
|
存储 算法
|
算法
算法题每日一练---第76天:丑数 l
丑数 就是只包含质因数 2、3 和 5 的正整数。
146 1
算法题每日一练---第76天:丑数 l
|
算法
算法题每日一练---第75天:Nim 游戏
你和你的朋友,两个人一起玩 Nim 游戏。
320 0
算法题每日一练---第75天:Nim 游戏
|
算法
算法题每日一练---第74天:快乐数
编写一个算法来判断一个数 n 是不是快乐数。
179 0
算法题每日一练---第74天:快乐数
|
存储 算法
算法题每日一练---第73天:加一
给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。
155 0
算法题每日一练---第73天:加一
|
算法
算法题每日一练---第72天:数字 1 的个数
给定一个整数 n,计算所有小于等于 n 的非负整数中数字 1 出现的个数。
224 0
算法题每日一练---第72天:数字 1 的个数
|
存储 算法
算法题每日一练---第71天:回文数
回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
151 0
算法题每日一练---第71天:回文数