C++解决三天打鱼两天晒网问题

2024-04-08 01:58

本文主要是介绍C++解决三天打鱼两天晒网问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题说明:

中国有句俗语叫“三天打鱼两天晒网”。某人从201011日起开始“三天打鱼两天晒网”,问这个人在以后的某一天中是“打鱼”还是“晒网”。用CC++语言/java/python实现程序解决问题。

基本要求:1.程序风格良好(使用自定义注释模板),提供友好的输入输出。

提高要求:1.输入数据的正确性验证。

2.使用文件进行数据测试。如将日期 20100101 20111214 等数据保存在in.txt文件中,程序读入in.dat文件进行判定,并将结果输出至out.txt文件。

设计思路:

根据题意可以将解题过程分为三步:
1)计算从2010年1月1日开始至指定日期共有多少天;
2)由于“打鱼”和“晒网”的周期为5天,所以将计算出的天数用5去除;
3)根据余数判断他是在“打鱼”还是在“晒网”;

计算两个日期间隔天数通过函数DateSum()实现,先年份递减累加天数,至2010年再月份递减累加天数,至2010年1月sum+day,得出总间隔天数。

实际实现功能:

1、程序风格良好,提供友好输入和输出;

2、输入数据的正确性验证;

3、判断指定日期,某人的状态。

 

 

 

源代码:

#include<iostream>
#include<fstream>
using namespace std;
class Date
{private:int year_;int month_;int day_;int sum_;public:Date(int y,int m,int d)	{year_=y;month_=m;day_=d;sum_=0;}int Determine();int DateSum();};/*函数Determine()用于判定年份是平年还是闰年,若闰年,返回值为1,平年为1*/ 
int Date::Determine()
{int a=0;if((year_%4==0&&year_%100!=0)||year_%400==0)a=1;return a;
}/*函数DateSum()计算从2010年1月1日开始至指定日期共有几天*/
int Date::DateSum()
{int OdYear[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};//数组OdYear[]表示平年的每月天数 int b,i;while(year_>2010){/*调用Determine(),并将返回值赋予b*/ b=Determine();for(i=1;i<13;i++)sum_+=OdYear[i];/*若此年为闰年,b=1,sum_加1,反之,加0*/sum_=b+sum_;year_--;}while(month_>1){sum_+=OdYear[month_];month_--;}sum_=sum_+day_;return sum_;
}
int main()
{int OdYear[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};//数组OdYear[]表示平年的每月天数int y,m,d;int a;int sum=0;cout<<"/***输入的日期要求始于2010年1月1日***/"<<endl;cout<<"请输入年月日格式如(2010 01 01):"<<endl; 	cin>>y>>m>>d;Date D1(y,m,d);a=D1.Determine();/*闰年情况下,平年2月份天数加1*/ OdYear[2]=28+a;/*判断日期是否合法*/ if(y<2010||(m<1||m>12)||(d>OdYear[m])){cout<<"输入日期非法!"<<endl;exit(1);}else	sum=D1.DateSum();cout<<"sum="<<sum<<endl;/*通过余数计算确定是打鱼还是休息*/if(sum%5==1||sum%5==2||sum%5==3)cout<<"此人在 "<<y<<" 年 "<<m<<" 月 "<<d<<" 日打鱼"<<endl; elsecout<<"此人在 "<<y<<" 年 "<<m<<" 月 "<<d<<" 日休息"<<endl;return 0;} 

学习心得:

程序编程过程中,前期准备工作非常重,明确功能要求和自身能力,完成程序的流程图,在面临大工程时能够帮助自己有条不紊的编程。

新人博主,能力有限,仍需不断学习,请多多包涵。

这篇关于C++解决三天打鱼两天晒网问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/884276

相关文章

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

详解C++中类的大小决定因数

《详解C++中类的大小决定因数》类的大小受多个因素影响,主要包括成员变量、对齐方式、继承关系、虚函数表等,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 非静态数据成员示例:2. 数据对齐(Padding)示例:3. 虚函数(vtable 指针)示例:4. 继承普通继承虚继承5.

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Spring事务中@Transactional注解不生效的原因分析与解决

《Spring事务中@Transactional注解不生效的原因分析与解决》在Spring框架中,@Transactional注解是管理数据库事务的核心方式,本文将深入分析事务自调用的底层原理,解释为... 目录1. 引言2. 事务自调用问题重现2.1 示例代码2.2 问题现象3. 为什么事务自调用会失效3

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

springboot报错Invalid bound statement (not found)的解决

《springboot报错Invalidboundstatement(notfound)的解决》本文主要介绍了springboot报错Invalidboundstatement(not... 目录一. 问题描述二.解决问题三. 添加配置项 四.其他的解决方案4.1 Mapper 接口与 XML 文件不匹配