[c语言]年份有关问题汇总(关于平闰年判断引发的系列问题)
1.所需装备:
☀平闰年的定义:平年有365天,闰年有366天;
☀利用数学如何判断:
判断任意年份是否为闰年,需要满足以下条件中的任意一个:
① 该年份能被 4 整除同时不能被 100 整除;
② 该年份能被400整除。
由上述描述可以得到如下结论:定义一个年份a,让它完成上面的需求即可:理论存在,代码走起!!!
int a;
①a%4==0&&a%100!=0
②a%400==0
当然,你也可以把二者结合起来写 a%4==0&&a%100!=0||a%400==0
,也可以这样写a%400==0|| a%4= =0&&a%100!=0
,都是ok的,因为&&的优先级高于||的优先级那么接下来我们用题目来举例子,一步一步细挖平闰年会给我们带来那些c语言上面的问题吧?
2.具体操作,细节打怪!!!
☀其实在平闰年里面,核心就是1天之差,而这个1天之差就是2月份到底28天还是29天,所以解决这些问题无非就是在判断上下功夫,更直接点就是if,else里利用前面所提到的判断知识来判断到底是平年还是闰年,然后在通过平闰年来判读2月份的天数,最后根据题目要求完成代码就可以,此类题目最多的就是需求复杂以及判读会不会失误,需要在完成代码后进行具体验证,希望下面的例子对你有帮助哟!!!
①判断平闰年
先热个身,就是玩!!!
#include <stdio.h>
int main()
{
int year,a;
printf("请输人年份:\n");
scanf("%d",&year);
if(year%400==0||year%4==0&&year%100!=0)
a=1;
else
a=0;
if(a==1)
{
printf("%d年是闰年\n",year);
}
else
{
printf("%d年平年\n",year);
}
return 0;
}
运行结果:
②输入某年某月,打印出该年份的天数。
先判断平闰年,然后在判断出2月份是多少天;然后大小月份可以利用switch语句或者是建立两个数组来进行输入。
①利用switch语句来判断大小月份以及2月份天数,加上break语句就可以实现。
优点:一目了然,缺点:不适合代码块迁移。
#include <stdio.h>
int main()
{
int year,month,days;
printf("输入年月:\n");
scanf("%d,%d",&year,&month);
switch(month)
{
case 1:
case 3:
case 5:
case 7:
case 8:
case 10:
case 12:days=31;break;
case 4:
case 6:
case 9:
case 11:days=30;break;
case 2:if(year%400==0||year%4==0&&year%100!=0) days=29;
else days=28; break;
default:printf("输入错误,一年只有12个月哦\n");
}
if(month>=1&&month<=12)
printf("%d年%d月有%d天\n",year,month,days );
return 0;
}
运行结果:
①输入正确的月份
②输入错误的月份
②利用两个数组分别数组分别存放平年和闰年的天数,然后利用数组下标来对应月份,因为数组下标最小值重0开始,但是月份是从1开始,那么我们只要从得到的月份减去1就可以返回对应的月份下标,然后返回值了。但是有一点需要注意的是一旦输入的数字大于12,还需要一个报错处理才行呀,利用if判断语句的嵌套就可以啦!!!
优点:利用函数,实现每一个所需要的功能,利于代码块迁移。
#include <stdio.h>
#include<stdlib.h>
int trans(int a) //自定义函数trans来判断平闰年
{
if (a%4==0&&a%100!=0||a%400==0) //闰年判断条件
return 1;//是闰年返回1
else
return 0; //是平年返回0
}
int number(int year,int month)
{
int potato = -1;//存放区,存放月份对应的天数
int a[12]={31,28,31,30,31,30,31,31,30,31,30,31};//数组a存放平年每月的天数
int b[12]={31,29,31,30,31,30,31,31,30,31,30,31};//数组b存放闰年每月的天数
if(month<12)
{
if(trans(year)==1)
potato=b[month-1];
else
potato=a[month-1];
}
else
{
printf("一年只有12个月哦!!!\n");
}
return potato;
}
int main()
{
int year,month,day,n;
printf("土豆哥666方法2,请输入年月\n");
scanf("%d,%d",&year,&month);
n=number(year,month);
if(n!=-1)
{
printf("%d年%d月是%d天 \n",year,month,n);
}
else
{
printf("您的输入有误哦!,请重新输入\n");
}
return 0;
}
运行结果:
①输入正确的月份
②输入错误的月份
③这里挖个坑,其实也可以利用二维数组,在利用指针的特性,来实现。嘻嘻,如果你有想法,可以把代码补充到评论区,如果你还有什么别的方法也欢迎您在评论区留言呀!!!(这个坑会在总结指针的时候补上的:到时候土豆哥会在评论区留下链接的)
③3天打鱼,2天晒网问题
这是个蛮经典的问题,就是在具体到总共的天数(利用循环累加来实现),然后总天数求余,除以5后,如果总天数在1到3之间,说明在打鱼,否则就是在嗮网。
题目来自万能的互联网呀,感谢感谢!!!
如果一个渔夫从 2011 年 1 月 1 日开始每三天打一次渔,两天晒一次网,编程实现当输入 2011 1 月 1 日以后的任意一天,输出该渔夫是在打渔还是在晒网。
#include <stdio.h>
int trans(int a) //判断平闰年
{
if (a%400==0||a%4==0&&a%100!=0) //闰年判断条件
return 1; /*是闰年返回1*/
else
return 0; /*不是闰年返回O*/
}
int number(int year,int month,int day) //计算输入日期距2011年1月1日共有多少天
{
int sum = 0, i, j, k;
int a[12]={31,28,31,30,31,30,31,31,30,31,30,31}; //数组a存放平年每月的天数
int b[12]={31,29,31,30,31,30,31,31,30,31,30,31}; //数组b存放闰年每月的天数
if(trans(year)==1)
for(i=0;i<month-1;i++)//累加到前一个月的天数
sum+=b[i];
else
for(i=0;i<month-1;i++)
sum+=a[i];
for(j=2011;j<year;j++)
if (trans(j)==1)//判断之前经过的到底是平年还是闰年,这里应该是1.
sum+=366;
else
sum+=365;
sum+=day; //计算总天数
return sum;
}
int main()
{
int year,month,day,n;
printf("请输入年月日\n");
scanf("%d,%d,%d",&year,&month,&day);
n=number(year,month,day);
if((n%5)<4&&(n%5)>0)
printf("%d年%d月%d日渔夫在打鱼\n",year,month,day);
else
printf("%d年%d月%d日渔夫在晒网\n",year,month,day);
return 0;
}
运行结果:
为了验证代码的正确性,画个图来看一下,
在第23行代码处,有时候可以看见这样的写法,if (trans(j)==i)
,如果要是这样写的,上述代码的运行结果为
和计算结果是不符合的。
再挖一个坑,如何利用结构体来实现三天打鱼,两天嗮网呢。欢迎大佬在下面评论呀!!!
感谢您能看到这里呀,如果有收获的话,麻烦给土豆哥点个赞呀!!!欢迎关注微信公众号土豆哥666,我们一起变的更好,加油啦!!!