首页 应用 游戏 资讯 攻略

C语言教程之打鱼还是晒网

时间:2011-06-24 关注公众号 来源:网络

  *问题分析与算法设计

  根据题意可以将解题过程分为三步:

  1)计算从1990年1月1日开始至指定日期共有多少天;

  2)由于“打鱼”和“晒网”的周期为5天,所以将计算出的天数用5去除;

  3)根据余数判断他是在“打鱼”还是在“晒网”;

  若 余数为1,2,3,则他是在“打鱼”

  否则 是在“晒网”

  在这三步中,关键是第一步。求从1990年1月1日至指定日期有多少天,要判断经历年份中是否有闰年,二月为29天,平年为28天。闰年的方法可以用伪语句描述如下:

  如果 ((年能被4除尽 且 不能被100除尽)或 能被400除尽)

  则 该年是闰年;

  否则 不是闰年。

  C语言中判断能否整除可以使用求余运算(即求模)

  *程序说明与注释

  #include<stdio.h>

  int days(struct date day);

  struct date{

  int year;

  int month;

  int day;

  };

  int main()

  {

  struct date today,term;

  int yearday,year,day;

  printf("Enter year/month/day:");

  scanf("%d%d%d",&today.year,&today.month,&today.day); /*输入日期*/

  term.month=12; /*设置变量的初始值:月*/

  term.day=31; /*设置变量的初始值:日*/

  for(yearday=0,year=1990;year<today.year;year++)

  {

  term.year=year;

  yearday+=days(term); /*计算从1990年至指定年的前一年共有多少天*/

  }

  yearday+=days(today); /*加上指定年中到指定日期的天数*/

  day=yearday%5; /*求余数*/

  if(day>0&&day<4) printf("he was fishing at that day.\n"); /*打印结果*/

  else printf("He was sleeping at that day.\n");

  }

  int days(struct date day)

  {

  static int day_tab[2][13]=

  {{0,31,28,31,30,31,30,31,31,30,31,30,31,}, /*平均每月的天数*/

  {0,31,29,31,30,31,30,31,31,30,31,30,31,},

  };

  int i,lp;

  lp=day.year%4==0&&day.year%100!=0||day.year%400==0;

  /*判定year为闰年还是平年,lp=0为平年,非0为闰年*/

  for(i=1;i<day.month;i++) /*计算本年中自1月1日起的天数*/

  day.day+=day_tab[lp][i];

  return day.day;

  }

  *运行结果

  Enter year/month/day:1991 10 25

  He was fishing at day.

  Enter year/month/day:1992 10 25

  He was sleeping at day.

  Enter year/month/day:1993 10 25

  He was sleeping at day.

阅读全文
扫码关注“ 多特资源库
更多更全的软件资源下载
文章内容来源于网络,不代表本站立场,若侵犯到您的权益,可联系我们删除。(本站为非盈利性质网站)
玩家热搜

相关攻略

正在加载中
版权
版权说明

文章内容来源于网络,不代表本站立场,若侵犯到您的权益,可联系我们删除。(本站为非盈利性质网站)

电话:13918309914

QQ:1967830372

邮箱:rjfawu@163.com

toast