打鱼还是晒网

今天在网上看到了c/c++趣味程序百例,于是学着里面的知识。

中国有句俗语叫“三天打鱼两天晒网”。某人从1990年1月1日起开始“三天打鱼两天晒网”,

问这个人在以后的某一天中是“打鱼”还是“晒网”。

*问题分析与算法设计
根据题意可以将解题过程分为三步:
1)计算从1990年1月1日开始至指定日期共有多少天;
2)由于“打鱼”和“晒网”的周期为5天,所以将计算出的天数用5去除;
3)根据余数判断他是在“打鱼”还是在“晒网”;
若 余数为1,2,3,则他是在“打鱼”
否则 是在“晒网”
在这三步中,关键是第一步。求从1990年1月1日至指定日期有多少天,要判断经历年份中是否有闰年,

二月为29天,平年为28天。闰年的方法可以用伪语句描述如下:

如果 ((年能被4除尽 且 不能被100除尽)或 能被400除尽)
则 该年是闰年;
否则 不是闰年。
C语言中判断能否整除可以使用求余运算(即求模)

*程序说明与注释

 1 #include<stdio.h>
 2 int days(struct date day);
 3 struct date{
 4 int year;
 5 int month;
 6 int day;
 7 };
 8
 9 int main()
10 {
11 struct date today,term;
12 int yearday,year,day;
13 printf("Enter year/month/day:");
14 scanf("%d%d%d",&today.year,&today.month,&today.day); /*输入日期*/
15 term.month=12; /*设置变量的初始值:月*/
16 term.day=31; /*设置变量的初始值:日*/
17 for(yearday=0,year=1990;year<today.year;year++)
18 {
19 term.year=year;
20 yearday+=days(term); /*计算从1990年至指定年的前一年共有多少天*/
21 }
22 yearday+=days(today); /*加上指定年中到指定日期的天数*/
23 day=yearday%5; /*求余数*/
24 if(day>0&&day<4) printf("he was fishing at that day.\n"); /*打印结果*/
25 else printf("He was sleeping at that day.\n");
26 }
27
28 int days(struct date day)
29 {
30 static int day_tab[2][13]=
31 {{0,31,28,31,30,31,30,31,31,30,31,30,31,}, /*平均每月的天数*/
32 {0,31,29,31,30,31,30,31,31,30,31,30,31,},
33 };
34 int i,lp;
35 lp=day.year%4==0&&day.year%100!=0||day.year%400==0;
36 /*判定year为闰年还是平年,lp=0为平年,非0为闰年*/
37 for(i=1;i<day.month;i++) /*计算本年中自1月1日起的天数*/
38 day.day+=day_tab[lp];
39 return day.day;
40 }

 以上是网上的版本,我运行了下,一推错误。。。。

于是修改了下,终于运行成功了,这对我这个c++新手来说非常的兴奋

 1 #include <iostream>
 2 #include<cmath>
 3 using namespace std;
 4
 5   int days(struct date day);
 6
 7   struct date{
 8     int year;
 9     int month;
10     int day;
11    };
12
13   int main()
14 {
15      struct date today,term;
16      int yearday,year,day;
17
18      cout<<"Enter year/month/day:"<<endl;
19      cin>>today.year>>today.month>>today.day; /*输入日期*/
20
21      term.month=12; /*设置变量的初始值:月*/
22      term.day=31; /*设置变量的初始值:日*/
23
24      for(yearday=0,year=1990;year<today.year;year++)
25     {
26        term.year=year;
27        yearday+=days(term); /*计算从1990年至指定年的前一年共有多少天*/
28      }
29
30      yearday+=days(today); /*加上指定年中到指定日期的天数*/
31      day=yearday%5; /*求余数*/
32
33      if(day>0&&day<4)
34          cout<<"he was fishing at that day.\n"; /*打印结果*/
35      else cout<<"He was sleeping at that day.\n";
36   }
37
38     int days(struct date day)
39 {
40    static int day_tab[2][12]=
41    {{0,31,28,31,30,31,30,31,31,30,31,30}, /*平均每月的天数*/
42    {0,31,29,31,30,31,30,31,31,30,31,30},
43    };
44
45    int i,lp;
46
47    if(day.year%400==0)
48     lp=1;
49    else
50     lp=0;
51 /*判定year为闰年还是平年,lp=0为平年,非0为闰年*/
52
53    for(i=1;i<day.month;i++) /*计算本年中自1月1日起的天数*/
54     day.day = day.day + day_tab[lp][i];
55
56     return day.day;
57 }

强迫症习惯了,直接变c++代码

时间: 2024-10-13 03:10:46

打鱼还是晒网的相关文章

打鱼晒网问题

题目描述:中国有句俗话叫“三天打鱼,两天晒网”.某人从1992年1月1日起开始“三天打鱼,两天晒网”,问:这个人在以后的某一天中是“打鱼”还是“晒网”? 解决这个题目分两步:1.距起始日期的天数,2.求余的结果 代码如下: 1 #include <stdio.h> 2 #include <stdlib.h> 3 4 typedef struct D{ 5 int year; 6 int month; 7 int day; 8 }Date; 9 10 int isleapyear(i

[转]100个经典C语言程序(益智类问题)

目录: 1.绘制余弦曲线 2.绘制余弦曲线和直线 3.绘制圆 4.歌星大奖赛 5.求最大数 6.高次方数的尾数 8.借书方案知多少 9.杨辉三角形 10.数制转换 11.打鱼还是晒网 12.抓交通肇事犯 13.该存多少钱 14.怎样存钱利最大 15.捕鱼和分鱼 16.出售金鱼 1.7 分数四则运算 17.平分七筐鱼 18.有限5位数 19. 8 除不尽的数 21.4位反序数 22.求车速 23.阿姆斯特朗数 24.完全数 26.亲密数 27.自守数 28.回文数 29.求具有abcd=(ab+c

回归经典之C语言《三天打鱼两天晒网》

//一个人从2000年1月1日开始三天打鱼两天晒网,用户输入一个日期,判断该人这天在打鱼还是晒网#include <stdio.h> void input();void sum(int y,int m,int d); int y,m,d; int main(void){ input(); sum(y,m,d); return 0;} void input(){ int ret; while(1) { ret=scanf("%d%d%d",&y,&m,&

java学习日记第三天之简单算法问题

hello 大家好 今天学习了一些有关java算法: 1.算法:解决问题的基本步骤,和实现方案 业务处理中的算法问题: 分析问题找规律 针对规律写代码 2.九九乘法口诀表 问题分析 : 1*1=1 1*2=2 2*2=2 1*3=3 2*3=6 3*3=9 我们发现规律 第几行有几个乘法式,需要两个遍历,从1-9行遍历,然后1-9列遍历 public class ReturnTest { public static void main(String[] args) { ReturnTest.ce

[转]100个经典C语言程序

本文转载自:http://blog.sina.com.cn/s/articlelist_1615065844_0_1.html 1.绘制余弦曲线 在屏幕上用“*”显示0~360度的余弦函数cos(x)曲线*问题分析与算法设计如果在程序中使用数组,这个问题十分简单.但若规定不能使用数组,问题就变得不容易了. 关键在于余弦曲线在0~360度的区间内,一行中要显示两个点,而对一般的显示器来说,只能按行输出,即:输出第一行信息后,只能向下一行输出,不能再返回到上一行. 为了获得本文要求的图形就必须在一行

《高级语言程序设计》习题集

<高级语言程序设计>习题集 (本资料仅供学生学习使用) ? ? 求最大数 借书方案知多少 杨辉三角形 数制转换 打鱼还是晒网 该存多少钱 怎样存钱利最大 出售金鱼 平分七筐鱼 有限5位数 8 除不尽的数 一个奇异的三位数 4位反序数 求车速 阿姆斯特朗数 完全数 亲密数 回文数 求素数 求具有abcd=(ab+cd)2性质的四位数 歌德巴赫猜想 百钱百鸡问题 爱因斯坦的数学题 换分币 年龄几何 三色球问题 马克思手稿中的数学题 最大公约数和最小公倍数 分数比较 分数之和 将真分数分解为埃及分数

03-1. 三天打鱼两天晒网(15)

中国有句俗语叫“三天打鱼两天晒网”.假设某人从某天起,开始“三天打鱼两天晒网”,问这个人在以后的第N天中是“打鱼”还是“晒网”? 输入格式: 输入在一行中给出1个不超过1000的正整数N. 输出格式: 在一行中输出此人在第N天中是“Fishing”(即“打鱼”)还是“Drying”(即“晒网”),并且输出“in day N”. 输入样例1: 103 输出样例1: Fishing in day 103 输入样例2: 34 输出样例2: Drying in day 34 #include "stdi

分支-03. 三天打鱼两天晒网(Switch…case)

中国有句俗语叫“三天打鱼两天晒网”.假设某人从某天起,开始“三天打鱼两天晒网”,问这个人在以后的第N天中是“打鱼”还是“晒网”? 输入格式:输入在一行中给出1个不超过1000的正整数N. 输出格式:在一行中输出此人在第N天中是“Fishing”(即“打鱼”)还是“Drying”(即“晒网”),并且输出“in day N”. 输入样例1:103输出样例1:Fishing in day 103输入样例2:34输出样例2:Drying in day 34 import java.util.Scanne

分支-03. 三天打鱼两天晒网

分支-03. 三天打鱼两天晒网 中国有句俗语叫"三天打鱼两天晒网".假设某人从某天起,开始"三天打鱼两天晒网",问这个人在以后的第N天中是"打鱼"还是"晒网"? 输入格式: 输入在一行中给出1个不超过1000的正整数N. 输出格式: 在一行中输出此人在第N天中是"Fishing"(即"打鱼")还是"Drying"(即"晒网"),并且输出"