//	C++年月日判断初步代码
#include <iostream>

using namespace std;

class Data
{
	int year;
	int month;
	int day;
public:
	//判断日期是否有效
	bool data_check(int _year,int _month,int _day)
	{
		year = _year;
		month =  _month;
		day = _day;

		if(0 > year || 2018 < year) return false;
		if(0 > month || 12 < month) return false;
		if(0 > day || 31 < day) return false;
		return true;
	}
	//判断是否是闰年
	bool leap_year(int _year)
	{
		year = _year;
		if(year%400 == 0 || (year%4 == 0 &&year%100 != 0))//能被4,400整除除去被100整除的都是闰年
		{
			return true;
		}
		else 
		{
			return false;
		}
	}
	//下一天的日期
	void nextday(int _year,int _month ,int _day)
	{
		
		year = _year;
		month = _month;
		day = _day;
		switch(month)
		{
			case 1:
				if(31 == day)
				{
					month++;
					day = 1;
					break;
				}
			case 2:
				if((28 == day &&!leap_year(year))||(29 == day &&leap_year(year)))
				{
					month++;
					day = 1;
					break;
				}
			case 3:
				if(31 == day)
				{
					month++;
					day = 1;
					break;
				}
			case 4:
				if(30 == day)
				{
					month++;
					day = 1;
					break;
				}
			case 5:
				if(31 == day)
				{
					month++;
					day =1;
					break;
				}
			case 6:
				if(30 == day)
				{
					month++;
					day =1;
					break;
				}
			case 7:
				if(31 == day)
				{
					month++;
					day = 1;
					break;
				}
			case 8:
				if(31 == day)
				{
					month++;
					day =1;
					break;
				}
			case 9:
				if(30 == day)
				{
					month++;
					day = 1;
					break;
				}
			case 10:
				if(31 == day)
				{
					month++;
					day = 1;
					break;
				}
			case 11:
				if(30 == day)
				{
					month++;
					day = 1;
					break;
				}
			case 12:
				if(31 == day)
				{
					year++;
					month = 1;
					day = 1;
					break;
				}
		}
		cout << year << "." << month << "." << day << endl;
	}
	//列出下n天或者前n天的日期
	void nextday(int _year,int _month,int _day,int n)
	{
		year = _year;
		month = _month;
		day = _day;
		if(0 < n)
		{
			
			for(n =n+1;n>0;n--)
			{
				switch(month)
				{
					case 1:
						if(31 == day)
						{
							month++;
							day = 1;
							break;
						}else {
							day++;
							break;
						}
					case 2:
						if((28 == day &&!leap_year(year))||(29 == day &&leap_year(year)))
						{
							month++;
							day = 1;
							break;
						}else {
							day++;
							break;
						}
					case 3:
						if(31 == day)
						{
							month++;
							day = 1;
							break;
						}else {
							day++;
							break;
						}
					case 4:
						if(30 == day)
						{
							month++;
							day = 1;
							break;
						}else {
							day++;
							break;
						}
					case 5:
						if(31 == day)
						{
							month++;
							day =1;
							break;
						}
					case 6:
						if(30 == day)
						{
							month++;
							day =1;
							break;
						}else {
							day++;
							break;
						}
					case 7:
						if(31 == day)
						{
							month++;
							day = 1;
							break;
						}else day++;
					case 8:
						if(31 == day)
						{
							month++;
							day =1;
							break;
						}else {
							day++;
							break;
						}
					case 9:
						if(30 == day)
						{
							month++;
							day = 1;
							break;
						}else {
							day++;
							break;
						}
					case 10:
						if(31 == day)
						{
							month++;
							day = 1;
							break;
						}else {
							day++;
							break;
						}
					case 11:
						if(30 == day)
						{
							month++;
							day = 1;
							break;
						}else {
							day++;
							break;
						}
					case 12:
						if(31 == day)
						{
							year++;
							month = 1;
							day = 1;
							break;
						}else {
							day++;
							break;
						}
				}
			cout << year << "." << month << "." << day << endl;
			}
		}
		if(0 > n)
		{
			
			for(n =n-1;n<0;n++)
			{
				switch(month)
				{
					case 1:
						if(1 == day)
						{
							year--;							
							month =12;
							day = 31;
							break;
						}else {
							day--;
							break;
						}
					case 2:
						if(1 == day)
						{
							month--;
							day = 31;
							break;
						}else {
							day--;
							break;
						}
					case 3:
						if(1 == day)
						{
							month--;
							if(leap_year(year))
							{
								day = 29;
							}else{
								day = 28;
							}
							break;
						}else {
							day--;
							break;
						}
					case 4:
						if(1 == day)
						{
							month--;
							day = 31;
							break;
						}else {
							day--;
							break;
						}
					case 5:
						if(1 == day)
						{
							month--;
							day =30;
							break;
						}else {
							day--;
							break;
						}
					case 6:
						if(1 == day)
						{
							month--;
							day =31;
							break;
						}else {
							day--;
							break;
						}
					case 7:
						if(1 == day)
						{
							month--;
							day = 30;
							break;
						}else {
							day--;
							break;
						}
					case 8:
						if(1 == day)
						{
							month--;
							day =31;
							break;
						}else {
							day--;
							break;
						}
					case 9:
						if(1 == day)
						{
							month--;
							day = 31;
							break;
						}else {
							day--;
							break;
						}
					case 10:
						if(1 == day)
						{
							month--;
							day = 30;
							break;
						}else {
							day--;
							break;
						}
					case 11:
						if(1 == day)
						{
							month--;
							day = 31;
							break;
						}else {
							day--;
							break;
						}
					case 12:
						if(1 == day)
						{
							month--;
							day = 31;
							break;
						}else {
							day--;
							break;
						}
				}
			cout << year << "." << month << "." << day << endl;
			}
		}
	}
	

};
int main()
{
	Data *data = new Data;
	int year = 1997;
	int month = 2;
	int day = 28;
	int n = -137;
	cout << data->data_check(year,month,day) << endl;
	cout << data->leap_year(year) << endl;
	data-> nextday(year,month,day);
	data-> nextday(year,month,day,n);
	
	
}

C++简单年月日的功能实现的更多相关文章

  1. ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能

    参考:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/examining-the-edit-method ...

  2. Web---创建Servlet的3种方式、简单的用户注册功能

    说明: 创建Servlet的方式,在上篇博客中,已经用了方式1(实现Servlet接口),接下来本节讲的是另外2种方式. 上篇博客地址:http://blog.csdn.net/qq_26525215 ...

  3. js+html+css简单的互动功能页面(2015知道几乎尖笔试题)http://v.youku.com/v_show/id_XMTI0ODQ5NTAyOA==.html?from=y1.7-1.2

    js+html+css实现简单页面交互功能(2015知乎前端笔试题) http://v.youku.com/v_show/id_XMTI0ODQ5NTAyOA==.html? from=y1.7-1. ...

  4. Spring 学习——基于Spring WebSocket 和STOMP实现简单的聊天功能

    本篇主要讲解如何使用Spring websocket 和STOMP搭建一个简单的聊天功能项目,里面使用到的技术,如websocket和STOMP等会简单介绍,不会太深,如果对相关介绍不是很了解的,请自 ...

  5. Django文件上传三种方式以及简单预览功能

    主要内容: 一.文件长传的三种方式 二.简单预览功能实现 一.form表单上传 1.页面代码 <!DOCTYPE html> <html lang="en"> ...

  6. 运用socket实现简单的ssh功能

    在python socket知识点中已经对socket进行了初步的了解,那现在就使用这些知识来实现一个简单的ssh(Secure Shell)功能. 首先同样是建立两个端(服务器端和客户端) 需求是: ...

  7. Jenkins实现简单的CI功能

    步骤一:安装JDK.Tomcat,小儿科的东西不在此详细描述 步骤二:下载安装Jenkins下载链接:https://jenkins.io/download/ 步骤三:将下载的jenkins.war部 ...

  8. jQuery实现简单前端搜索功能

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. Unity UGUI 实现简单拖拽功能

    说到拖拽,那必然离不开坐标,UGUI 的坐标有点不一样,它有两种坐标,一种是屏幕坐标,还有一种就是 UI 在Canvas内的坐标(暂时叫做ugui坐标),这两个坐标是不一样的,所以拖拽就需要转换. 因 ...

随机推荐

  1. [題解]luogu P1156 垃圾陷阱

    前言:[數據刪除] 來源:題解 不發題面了 首先我们来分析题目,“每个垃圾都可以用来吃或堆放”,浓浓的透露出一个背包气息.我们可以类比背包问题的放或不放.于是dp[i][j]dp[i][j]dp[i] ...

  2. flask环境安装

    virtualenv venv #创建venv .venv/bin/activate #进入venv venv/bin/pip install flask venv/bin/pip install f ...

  3. C# 基础之密封类

    C#密封类 一.密封类 1. 密封类的定义 如果我们不希望自己编写的类被继承:如果有的类已经没有再被继承的必要,这时,我们可以使用sealed修饰符在类中进行声明,以达到该类不能派生其它类的目的,该类 ...

  4. C#基础之方法

    方法组成为: public void Fun(string name) { 代码块 } 1.方法的访问级别:修饰符,即上边的Public 2.返回类型:方法是否具有返回值,上边方法无返回值即为void ...

  5. [软件工程基础]2017.11.04 第八次 Scrum 会议

    具体事项 项目交接燃尽图 每人工作内容 成员 已完成的工作 计划完成的工作 工作中遇到的困难 游心 #10 搭建可用的开发测试环境:#9 阅读分析 PhyLab 后端代码与文档:#8 掌握 Larav ...

  6. 【aspnetcore】异常捕捉可用知识点

    1.使用过滤器ExceptionFilter:补充:常用过滤器:AuthorizationFilter.ActionFilter.ResultFilter.ResourceFilter.Excepti ...

  7. MFC中的模态对话框与非模态对话框

    模态对话框创建: MyDialog mydlg; mydlg.DoModal() 当前只能运行此模态对话框,且停止主窗口的运行,直到模态对话框退出,才允许主窗口运行. 模态对话框的关闭顺序: OnCl ...

  8. [已读]移动web手册

    冲着作者是PPK才买的,双色,180页,略贵.但是这本书的内容,我并不是很满意.4.5.6三章算是干货,尤其是第四章,值得一读.其他的内容,忽略就好了.

  9. java中的线程安全是什么?什么叫线程安全?什么叫不安全?

    java中的线程安全是什么: 就是线程同步的意思,就是当一个程序对一个线程安全的方法或者语句进行访问的时候,其他的不能再对他进行操作了,必须等到这次访问结束以后才能对这个线程安全的方法进行访问 什么叫 ...

  10. apache配置优化 - 解决apache环境下网站访问速度慢的问题(重点参考)

    如果apche访问量过大,将会导致页面打开迟缓,下载速度也降低,如果由于经费和环境问题,集群方案没有得以应用.可以通过对Apache2增加模块MPM来进行优化, 这里我选择线程型MPM加以优化:  开 ...