输入一个日期,判断这个日期在一年中是哪一天,是星期几,计算两个日期间的天数,使用字符串输出日期

本文主要是介绍输入一个日期,判断这个日期在一年中是哪一天,是星期几,计算两个日期间的天数,使用字符串输出日期,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

之前写了一个博文(http://blog.csdn.net/shiwazone/article/details/45053739)是用基本函数实现的,这次使用类的设计方法,也就是面向对象的方法改写一下,并加入了日期转换成字符串的实现。这里的程序也可以解决编程珠玑习题3.4的问题。

#include"calendar.h"
int main()
{Time t;t.initialTime();t.Show();t.StrShow();Time t1;t1.initialTime();t1.StrShow();Time t2;t2.initialTime();t2.StrShow();cout << "The days between t1 and t2 is: " << t1.countdays(t2)<<endl;cout << "The days between t2 and t1 is: " << t2.countdays(t1)<<endl;return 0;
}
#ifndef CANLENDAR_H
#define CANLENDAA_H
#include<iostream>
#include<string>
using namespace std;
string ntos(int t);//数字转换成字符
class Time
{
private:int year;int month;int day;unsigned int weekday;int Weekdaycount()const;//计算当日是星期几int Daycount()const;//计算当日是公元第多少天int Daysyearcount()const;//计算当日是该年的第多少天bool isleapyear()const;//判断该年是不是闰年bool check()const;//检查时间格式是否正确void numtostr(string &sy, string &sm, string &sd, string &sw)const;//数字日期转换成字符日期public:void initialTime();//输入初始化时间void Show()const;//显示时间信息void StrShow()const;//使用字符串的表达显示日期int countdays(const Time & t2)const;//计算两个日期间的天数
};
int Time::Weekdaycount()const//计算当日是星期几
{return Daycount() % 7;
}
int Time::Daycount()const//计算当日是公元第多少天
{int days = 0;days = (year - 1) * 365 + (year - 1) / 4 - (year - 1) / 100+ (year - 1) / 400 + Daysyearcount();return days;
}
int Time::Daysyearcount()const//计算当日是该年的第多少天
{int days = 0;int mtemp = month - 1;while (mtemp > 0){switch (mtemp){case(1) :case(3) :case(5) :case(7) :case(8) :case(10) :case(12) :days += 31; break;case(4) :case(6) :case(9) :case(11) :days += 30; break;case(2) :days += 28; break;default:break;}--mtemp;}if (isleapyear())++days;//如果是闰年,再加上一天return days + day;//返回计算的天数加上当月的天数
}
bool Time::isleapyear()const//判断该年是不是闰年
{if (year % 4 == 0 && year % 100 != 0) return true;//年是四的倍数而且不是100的倍数,是闰年if (year % 400 == 0)return true;else return false;
}
bool Time::check()const//检查时间格式是否正确
{if (year <= 0 || (month <= 0 || month>12) || day <= 0) return false;else{if (( month == 1 ||  month == 3 ||  month == 5 ||  month == 7||  month == 8 ||  month == 10 ||  month == 12) &&  day > 31)return false;else{if (( month == 4 ||  month == 6 ||  month == 9 ||  month == 11) &&  day > 30)return false;else{if ( month == 2) {if (isleapyear()) {if ( day > 29)return false; else return true;}else{if ( day > 28)return false; else return true;}}}}}
}
void Time::numtostr(string &sy, string &sm, string &sd, string &sw)const//数字日期转换成字符日期
{sy = ntos(year / 1000) + ntos(year / 100 - 10 * (year / 1000)) + ntos(year / 10 - 10 * (year / 100)) + ntos(year % 10);sd = ntos(day / 10) + ntos(day % 10);switch (month){case(1) : sm = "January"; break;case(2) : sm = "February"; break;case(3) : sm = "March"; break;case(4) : sm = "April"; break;case(5) : sm = "May"; break;case(6) : sm = "June"; break;case(7) : sm = "July"; break;case(8) : sm = "August"; break;case(9) : sm = "September"; break;case(10) : sm = "October"; break;case(11) : sm = "November"; break;case(12) : sm = "December"; break;default:break;}switch (weekday){case(1) : sw = "Monday"; break;case(2) : sw = "Tuesday"; break;case(3) : sw = "Wednesday"; break;case(4) : sw = "Thursday"; break;case(5) : sw = "Friday"; break;case(6) : sw = "Saturday"; break;case(7) : sw = "Sunday"; break;default:break;}
}void Time::initialTime()//输入初始化时间
{cout << "Enter the Time (year,month,day):\n";cin >> year;cin.get();cin >> month;cin.get();cin >> day;cin.get();if (!check()){ cout << "Try again:\n"; initialTime(); }elseweekday = Weekdaycount();
}
void Time::Show()const//显示时间信息
{cout << "Year: " << year << "\t";cout << "Month: " << month << "\t";cout << "Day: " << day << "\t";cout << "Weekday: " << weekday << endl;cout << "This is a ";if (isleapyear())cout << "leap"; else cout << "nonleap";cout << " year.\n";cout << "Today is the " << Daysyearcount() << " days of the year.\n";
}
void Time::StrShow()const//使用字符串的表达显示日期
{string st, sy, sm, sd, sw;numtostr( sy, sm, sd, sw);st = sy + " / " + sm + " / " + sd + " ," + "Today is " + sw + " .";string::iterator it = st.begin();for (; it != st.end(); ++it)cout << *it;cout << endl;cout << "This is a ";if (isleapyear())cout << "leap"; else cout << "nonleap";cout << " year.\n";cout << "Today is the " << Daysyearcount() << " days of the year.\n";
}
int Time::countdays(const Time & t2)const//计算两个日期间的天数
{int t = Daycount() - t2.Daycount();if (t < 0) return -t;return t;
}string ntos(int t)//数字转换成字符
{switch (t){case(0) : return "0";case(1) : return "1";case(2) : return "2";case(3) : return "3";case(4) : return "4";case(5) : return "5";case(6) : return "6";case(7) : return "7";case(8) : return "8";case(9) : return "9";default:break;}
}
#endif


如需转载,请注明出处。

这篇关于输入一个日期,判断这个日期在一年中是哪一天,是星期几,计算两个日期间的天数,使用字符串输出日期的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

poj 3259 uva 558 Wormholes(bellman最短路负权回路判断)

poj 3259: 题意:John的农场里n块地,m条路连接两块地,w个虫洞,虫洞是一条单向路,不但会把你传送到目的地,而且时间会倒退Ts。 任务是求你会不会在从某块地出发后又回来,看到了离开之前的自己。 判断树中是否存在负权回路就ok了。 bellman代码: #include<stdio.h>const int MaxN = 501;//农场数const int

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的