C,C++,Python怎么实现“三天打鱼两天晒网”的渔夫打鱼晒网问题?

阅读: 评论:0

C,C++,Python怎么实现“三天打鱼两天晒网”的渔夫打鱼晒网问题?

C,C++,Python怎么实现“三天打鱼两天晒网”的渔夫打鱼晒网问题?

文章目录

  • 1.问题描述
  • 2.怎么实现
  • 3.代码实现
    • 1.Python实现
    • 2.C语言实现
    • 3.C++实现

1.问题描述

如果一个渔夫从 2011 年 1 月 1 日开始每三天打一次渔,两天晒一次网,编程实现当输入 2011 1 月 1 日以后的任意一天,输出该渔夫是在打渔还是在晒网。

2.怎么实现

(1) 自定义函数 leap(),用来判断输入的年份是否是闰年。
(2) 自定义函数 number(),用来计算输入日期距 2011 年 1 月 1 日共有多少天。
(3)然后就可以计算出在那天,渔夫是在打鱼还是晒网?

3.代码实现

1.Python实现

源代码:


def leap(b):if ((b%4==0) and (b%100 != 0) or (b%400==0)):return 1else:return 0
def number(y,m,d):global sumsum = 0a=[31,28,31,30,31,30,31,31,30,31,30,31]    # 数组a存放平年每月的天数b=[31,29,31,30,31,30,31,31,30,31,30,31]    # 数组b存放闰年每月的天数if leap(y)==1:   # 判断是否为闰年for i in range(m):sum+=b[i]    # 是闰年,累加数组b前m-1个月份的天数i+=1else:for i in range(m):sum+=a[i]   # 不是闰年,累加数组a前m-1个月份的天数for j in range(2011,y+1):if leap(j)==i:sum+=366    # 2011年到输入的年份是闰年的加366else:sum+=365   # 2011年到输入的年份不是闰年的加365i+=1sum= sum+d   # 将前面累加的结果加上日期,求出总天数return sum   # 返回计算的天数
time = input('请输入日期 YYYY-MM-DD:')
data = time.split("-")
year = int(data[0])
month = int(data[1])
day = int(data[2])
n=number(year,month,day)   # 调用函数 number()
if((n%5) ==4 or (n%5)==5):   # 余数是1或2或3时说明在打渔,否则在晒网print("%d:%d:%d 晒网n" % (year, month, day))else:print("%d:%d:%d 打鱼n" % (year, month, day))

运行结果:

2.C语言实现

源代码:

#include <stdio.h>
int leap(int a) /*自定义函数leap()用来指定输入的年份是否为闰年*/
{if (a%4==0&&a%100!=0||a%400==0)    /* 闰年判定条件 */return 1;    /*是闰年返回1*/elsereturn 0;    /*不是闰年返回O*/
}int number(int year,int month,int day)    /*自定义函数 number() 计算输入日期距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(leap(year)==1)    /*判断是否为闰年*/for(i=0;i<month-1;i++)sum+=b[i];    /*是闰年,累加数组b前m-1个月份的天数*/elsefor(i=0;i<month-1;i++)sum+=a[i];    /*不是闰年,累加数组a前m-1个月份的天数*/for(j=2011;j<year;j++)if (leap(j)==i)sum+=366;    /*2011年到输入的年份是闰年的加366*/elsesum+=365;    /*2011年到输入的年份不是闰年的加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);    /*调用函数 number()*/if((n%5)<4&&(n%5)>0)    /*余数是1或2或3时说明在打渔,否则在晒网*/printf("%d:%d:%d 打鱼n",year,month,day);elseprintf("%d:%d:%d 晒网n",year,month,day);return 0;
}

运行结果:

3.C++实现

源代码:

#include <iostream>using namespace std;int leap(int a) /*自定义函数leap()用来指定输入的年份是否为闰年*/
{if (a%4==0&&a%100!=0||a%400==0)    /* 闰年判定条件 */return 1;    /*是闰年返回1*/elsereturn 0;    /*不是闰年返回O*/
}int number(int year,int month,int day)    /*自定义函数 number() 计算输入日期距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(leap(year)==1)    /*判断是否为闰年*/for(i=0;i<month-1;i++)sum+=b[i];    /*是闰年,累加数组b前m-1个月份的天数*/elsefor(i=0;i<month-1;i++)sum+=a[i];    /*不是闰年,累加数组a前m-1个月份的天数*/for(j=2011;j<year;j++)if (leap(j)==i)sum+=366;    /*2011年到输入的年份是闰年的加366*/elsesum+=365;    /*2011年到输入的年份不是闰年的加365*/sum+=day;    /*将前面累加的结果加上日期,求出总天数*/return sum;    /*返回计算的天数*/
}int main()
{int year,month,day,n;cout<<"请输入年月日n"<<endl;cin>>year>>month>>day;    /*输入年月日*/n=number(year,month,day);    /*调用函数 number()*/if((n%5)<4&&(n%5)>0)    /*余数是1或2或3时说明在打渔,否则在晒网*/cout<<year<<"年"<<month<<"月"<<day<<"日"<<"打鱼n"<<endl;elsecout<<year<<"年"<<month<<"月"<<day<<"日"<<"晒网n"<<endl;return 0;
}

运行结果:

这篇文章主要通过三种语言实现三天打鱼,两天晒网,欢迎大家用自己喜欢的语言写出来,评论,大家相互学习,相互借鉴。

本文发布于:2024-02-03 01:15:26,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170689414947686.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

下一篇:打鱼or晒网
标签:两天晒网   渔夫   Python
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23