//	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. 字符串匹配,KMP算法

    KMP的详解见:https://segmentfault.com/a/1190000008575379 主要难点在于Next数组的理解,KMP是不需要回溯的匹配算法. #include<iost ...

  2. Jquery | 外部插入节点

    after(content) : //在 span 元素外部的后面 插入 "<span><b>Write Less Do More</b><span ...

  3. Hive_Hive的安装

    嵌入模式不推荐使用. 本地模式多用于开发和测试. 远程模式多用于生产环境.

  4. Action类为何要 extends ActionSupport以及实现ModelDriven

    http://blog.sina.com.cn/s/blog_164e377490102wqhk.html

  5. python学习day11

    目录 SqlAlchemy 外键 SqlAlechemy SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象 ...

  6. Unity Shader入门精要学习笔记 - 第10章 高级纹理

    转载自 冯乐乐的 <Unity Shader入门精要> 立方体纹理 在图形学中,立方体纹理是环境映射的一种实现方法.环境映射可以模拟物体周围的环境,而使用了环境映射的物体可以看起来像镀了层 ...

  7. C# 连接 Oracle,读取Blob字段数据,存到文件中去,包括pdf等等

    代码如下,记得引入Oracle的dll using System; using System.Collections.Generic; using System.ComponentModel; usi ...

  8. Java编程基础-方法

    1.方法(函数)概要 (1).含义:方法(函数)就是定义在类中的具有特定功能的一段独立小程序. (2).方法定义的语法格式:        修饰符 返回值类型 方法名(参数类型 参数名1,参数类型 参 ...

  9. UVM之uvm_phase

    UVM中的phase机制很有意思,它能让UVM启动之后,自动执行所有的流程.UVM 的user guide 中对uvm_phase的定义如下: This base class defines ever ...

  10. FZU 1977 Pandora adventure (插头DP,常规)

    题意:有一个n*m矩阵,其中有些格子必走,有些格子不可走,其他格子是可走也可不走,问有多少条哈密顿回路? 思路: 本来是一道很简单的题,代码写多了连白痴bug都查不出了,竟然用i>=ex& ...