C++简单年月日的功能实现
// 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++简单年月日的功能实现的更多相关文章
- ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能
参考:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/examining-the-edit-method ...
- Web---创建Servlet的3种方式、简单的用户注册功能
说明: 创建Servlet的方式,在上篇博客中,已经用了方式1(实现Servlet接口),接下来本节讲的是另外2种方式. 上篇博客地址:http://blog.csdn.net/qq_26525215 ...
- 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. ...
- Spring 学习——基于Spring WebSocket 和STOMP实现简单的聊天功能
本篇主要讲解如何使用Spring websocket 和STOMP搭建一个简单的聊天功能项目,里面使用到的技术,如websocket和STOMP等会简单介绍,不会太深,如果对相关介绍不是很了解的,请自 ...
- Django文件上传三种方式以及简单预览功能
主要内容: 一.文件长传的三种方式 二.简单预览功能实现 一.form表单上传 1.页面代码 <!DOCTYPE html> <html lang="en"> ...
- 运用socket实现简单的ssh功能
在python socket知识点中已经对socket进行了初步的了解,那现在就使用这些知识来实现一个简单的ssh(Secure Shell)功能. 首先同样是建立两个端(服务器端和客户端) 需求是: ...
- Jenkins实现简单的CI功能
步骤一:安装JDK.Tomcat,小儿科的东西不在此详细描述 步骤二:下载安装Jenkins下载链接:https://jenkins.io/download/ 步骤三:将下载的jenkins.war部 ...
- jQuery实现简单前端搜索功能
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Unity UGUI 实现简单拖拽功能
说到拖拽,那必然离不开坐标,UGUI 的坐标有点不一样,它有两种坐标,一种是屏幕坐标,还有一种就是 UI 在Canvas内的坐标(暂时叫做ugui坐标),这两个坐标是不一样的,所以拖拽就需要转换. 因 ...
随机推荐
- 字符串匹配,KMP算法
KMP的详解见:https://segmentfault.com/a/1190000008575379 主要难点在于Next数组的理解,KMP是不需要回溯的匹配算法. #include<iost ...
- Jquery | 外部插入节点
after(content) : //在 span 元素外部的后面 插入 "<span><b>Write Less Do More</b><span ...
- Hive_Hive的安装
嵌入模式不推荐使用. 本地模式多用于开发和测试. 远程模式多用于生产环境.
- Action类为何要 extends ActionSupport以及实现ModelDriven
http://blog.sina.com.cn/s/blog_164e377490102wqhk.html
- python学习day11
目录 SqlAlchemy 外键 SqlAlechemy SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象 ...
- Unity Shader入门精要学习笔记 - 第10章 高级纹理
转载自 冯乐乐的 <Unity Shader入门精要> 立方体纹理 在图形学中,立方体纹理是环境映射的一种实现方法.环境映射可以模拟物体周围的环境,而使用了环境映射的物体可以看起来像镀了层 ...
- C# 连接 Oracle,读取Blob字段数据,存到文件中去,包括pdf等等
代码如下,记得引入Oracle的dll using System; using System.Collections.Generic; using System.ComponentModel; usi ...
- Java编程基础-方法
1.方法(函数)概要 (1).含义:方法(函数)就是定义在类中的具有特定功能的一段独立小程序. (2).方法定义的语法格式: 修饰符 返回值类型 方法名(参数类型 参数名1,参数类型 参 ...
- UVM之uvm_phase
UVM中的phase机制很有意思,它能让UVM启动之后,自动执行所有的流程.UVM 的user guide 中对uvm_phase的定义如下: This base class defines ever ...
- FZU 1977 Pandora adventure (插头DP,常规)
题意:有一个n*m矩阵,其中有些格子必走,有些格子不可走,其他格子是可走也可不走,问有多少条哈密顿回路? 思路: 本来是一道很简单的题,代码写多了连白痴bug都查不出了,竟然用i>=ex& ...