include <stdio.h>

typedef struct date {//定义一个日期结构体date,三个成员变量year\month\day,使得年月日作为一个整体,相互联系。

//结构体:【适用形式:typedef struct m{ int a;int b;int c }M;M c;】【typrdef:类型定义、说明】-将struct m命名为M,再定义结构体变量-M c;

int year;

int month;//结构体一般形式:【struct 类型名{成员列表}变量;小心分号】在C语言中,结构体(struct)指的是一种数据结构,是C语言中聚合数据类型的一类。结构体可以被声明为变量、指针或数组等,用以实现较复杂的数据结构。结构体同时也是一些元素的集合,这些元素称为结构体的成员,且这些成员可以为不同的类型,成员一般用名字访问。

int day;

}DATE;

int countDay(DATE);//声明函数countDay\runYear接受DATE\int类型参数,countDay(year、month、day)表示指定(年、月、日),runYear函数为判断闰年

int runYear(int);

void main()

{

DATE today;//指定日期-定义结构体变量

int totalDay;//指定日期距离1990年1月1日的天数

int result;//totalDay对5取余的结果

printf("please input 指定日期 包括年, 月, 日 如:1999 1 31\n");//输入指定的日期,包括年月日

scanf_s("%d%d%d",&today.year,&today.month,&today.day);//scanf输入可能不安全,可替换使用scanf_s

//求出指定日期距离1990年1月1日的天数

totalDay = countDay(today);

//天数%5,判断输出打鱼还是晒网

result = totalDay % 5;//每5天一个周期,%为取余运算

if (result > 0 && result < 4)//判断每一个周期的5天内,取余结果为1—3:前三天是打鱼,取余结果为4、5:后两天是晒网。即三天打鱼两天晒网,&&(逻辑与)有一个为0则结果为0。

printf("今天打鱼");

else

printf("今天晒网");

}

int runYear(int year)//闰年判断函数runYear函数的函数体

{//闰年:如果(该年能被4整除并且不能被100整除)或者(该年能被400整除则是闰年)

if ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0))//判断指定日期是否闰年,是返回1,否返回0,||(逻辑或)有一个为1则判断结果为1。

return 1;

else

return 0;

}

//求指定日期距离1990年1月1日的天数-算法核心部分【到指定日期距离1990年1月1日的天数totalDay=1990年至指定日期前一年共有多少天+指定年中到指定日期的天数】

int countDay(DATE currentDay)//countDay函数计算指定日期距离1990年1月1日的天数,的函数体,函数定义:函数名(countDay)类型(DATE)参数(currentDay表示指定日期)

{

int perMonth[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };//每月天数数组,数组初始化,数组是一种数据结构,用于存储一组相同类型的数据。它可以按照索引来访问和操作其中的元素,使得对数据的处理更加方便和高效。

int totalDay = 0, year, i;

for (year = 1990; year < currentDay.year; year++)//将年份作为循环变量,求指定年之前的每年的天数累加和

{

if (runYear(year))//如果指定年份前的某一年为闰年则执行totalDay = totalDay + 366;//否则执行totalDay = totalDay + 365;

totalDay = totalDay + 366;

else

totalDay = totalDay + 365;

}

if (runYear(currentDay.year))//判断指定年是否为闰年,若是则该年2月加一天

perMonth[2] += 1;//是闰年则2月加一天为29天

for (i = 0; i < currentDay.month; i++)//将本年内的天数累加到totalDay

totalDay += perMonth[i];//计算指定日期到指定日期年初的天数,a+=b;含义同a=a+b;赋值运算将右运算结果赋给左变量

totalDay += currentDay.day;//将本月的天数累加到totalDay

return totalDay;//返回totalDay的值

}

C语言趣味编程之三天打鱼两天晒网的更多相关文章

  1. c语言趣味编程(3)打鱼还是筛网

    一.问题描述 中国有句俗语叫"三天打鱼两天晒网".某人从1990年1月1日起开始"三天打鱼两天晒网",问这个人在以后的以后的某一天中是打鱼还是晒网. 二.设计思 ...

  2. c语言趣味编程(4)抓交通肇事犯

    一.问题描述 一辆卡车违反交通规则,撞人后逃跑.现场有三人目击该事件,但都没有记住车号,只记下车号的一些特征. 甲说:牌照的前两位数字是相同的: 乙说:牌照的后两位数字是相同的,但与前两位不同: 丙是 ...

  3. c语言趣味编程(2)借书方案知多少

    一.问题描述 小明有5本新书,要借给A,B,C这三位小朋友,若每次每人只能借一本,则可以有多少种不同的借法? 二.设计思路 (1)定义三个变量a,b,c来代表三位小朋友借的书的编号 (2)利用for循 ...

  4. c语言趣味编程(1)百钱百鸡

    一.问题描述 百钱买百鸡问题:公鸡五文钱一只,母鸡三文钱一只,小鸡三只一文钱,用100文钱买100只鸡,公鸡.母鸡.小鸡各买多少只 二.设计思路 (1)定义三个变量下x,y,z代表公鸡,母鸡,小鸡的数 ...

  5. 【算法】C语言趣味程序设计编程百例精解

    C语言趣味程序设计编程百例精解 C/C++语言经典.实用.趣味程序设计编程百例精解(1)  https://wenku.baidu.com/view/b9f683c08bd63186bcebbc3c. ...

  6. 【转载】ANSYS的APDL与C语言混合编程(实例)

    原文地址:http://www.cnblogs.com/lyq105/archive/2010/05/04/1727557.html 本文讨论的不是利用C语言为ANSYS写扩展(或者说是用户子程序), ...

  7. [收藏转贴]struct探索·extern "C"含义探索 ·C++与C的混合编程·C 语言高效编程的几招

    一.C/C++语言 struct深层探索 1.自然对界 struct是一种复合数据类型,其构成元素既可以是基本数据类型(如 int.long.float等)的变量,也可以是一些复合数据类型(如 arr ...

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

    /*B3-分支-03. 三天打鱼两天晒网 *Main.c *测试通过 */ #include <stdio.h> #include <stdlib.h> int main() ...

  9. Mysql C语言API编程入门讲解

    原文:Mysql C语言API编程入门讲解 软件开发中我们经常要访问数据库,存取数据,之前已经有网友提出让鸡啄米讲讲数据库编程的知识,本文就详细讲解如何使用Mysql的C语言API进行数据库编程.   ...

  10. 为什么还坚持.NET? 找一门适合自己的语言去做编程

    为什么还坚持.NET? 找一门适合自己的语言去做编程 接触了.NET快十二年了,现在专注于分布式服务的开发. 中间经历过各种编程语言的诱惑,ios等. 前几年才对自己有比较明确的定位 技术上:找到适合 ...

随机推荐

  1. C语言输出键盘

    使用printf()函数输出样式 #include <stdio.h> int main() { printf("┌───┬───┬───┬───┬───┬───┬───┬─── ...

  2. Pytest 源码解读 [1] - [pluggy] 核心设计理念浅读

    背景: Pytest 是一个功能强大的 Python 测试框架,它使用了一个名为 "pluggy" 的插件系统来扩展其功能.在 Pytest 的源码中,pluggy 模块负责实现插 ...

  3. LyScript 实现应用层钩子扫描器

    Capstone 是一个轻量级的多平台.多架构的反汇编框架,该模块支持目前所有通用操作系统,反汇编架构几乎全部支持,本篇文章将运用LyScript插件结合Capstone反汇编引擎实现一个钩子扫描器. ...

  4. SpringBoot2.7集成Swagger3

    1.引入pom坐标 <!--swagger--> <dependency> <groupId>io.springfox</groupId> <ar ...

  5. 【算法】基于hoare快速排序的三种思想和非递归,基准值选取优化【快速排序的深度剖析-超级详细的注释和解释】你真的完全学会快速排序了吗?

    文章目录 前言 什么是快速排序 快速排序的递归实现 快速排序的非递归实现 单趟排序详解 hoare思想 挖坑法 前后指针法 快速排序的优化 三数取中 小区间优化 快速排序整体代码 尾声 前言 先赞后看 ...

  6. Bi-VAEGAN:对TF-VAEGAN提出的视觉到语义进一步改进

    论文"Bi-directional Distribution Alignment for Transductive Zero-Shot Learning"提出Bi-VAEGAN,它 ...

  7. 解决npm 下载速度慢的问题

    更换源,这个是最直接方便 有保障的方法了,不要去安装cnpm,因为你无法确定 他是否做了后门.!! 1. 如果不想安装cnpm 又想使用淘宝服务器来下载扩展插件:(这种方法 每次都得带 废弃) npm ...

  8. 【CAS学习一】CAS服务端部署

    公司要做单点登录系统,网上搜了一下目前主流方案是CAS,故部署一个试试看. 1.下载 因为最近出现log4j2远程代码执行漏洞,尽量选择新版本已修复此漏洞的,故CAS选择6.4版本.打包部署依赖JDK ...

  9. .NET Core开发实战(第25课:路由与终结点:如何规划好你的Web API)--学习笔记(下)

    25 | 路由与终结点:如何规划好你的Web API 自定义约束实现了路由约束接口,它只有一个 Match 方法,这个方法传入了 Http 当前的 httpContext,route,routeKey ...

  10. [数据库] 数据库中的DDL、DML、DQL、DCL

    SQL 程序语言有四种类型,对数据库的基本操作都属于这四种类,也就是标题上显示的 DDL.DML.DQL.DCL. 1. DDL DDL(Data Definition Language 数据定义语言 ...