打鱼晒网问题

问题如下:如果一个渔夫从2011年1月1日开始每三天打一次渔,两天晒一次网,编程显示以后的任意一天渔夫是在晒网还是打渔。
分析问题:首先看一下这个题,经过读题我们得知条件“三天打鱼两天晒网”,首先我们要考虑以后的任意一天所在的年份是否为闰年,然后计算这天距离2011年相差几天,然后进行计算,代码如下:

#include <stdio.h>
int leap(int a)
{
	if(a%4==0&&a%100!=0||a%400==0)
		return 1;
	else
		return 0;
}
int number(int year,int m,int d)
{
	int sum=0,i,j,k,a[12]={31,28,31,30,31,30,31,31,30,31,30,31};
	int b[12]={31,29,31,30,31,30,31,31,30,31,30,31};
	if(leap(year)==1)
		for(i=0;i<m-1;i++)
			sum=sum+=a[i];
		for(i=0;i<m-1;i++)
			sum=sum+=a[i];
		for(leap(j)==1)
			sum+=366;
		else
			sum+=365;
			sum+=d;
		return sum;
}
int mian()
{
	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);
}

代码解析:我们看一下这部分代码,可以看出我们写了两个函数分别计算天数和判断是否为闰年,最后进行判断余数是否为1,2,3,即可解出这个题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值