当前时间的下一秒

简介:
#include <iostream>
#include <cassert>
using namespace std;

class CTime
{
private:
	int year;
	int month;
	int day;
	int hour;
	int minute;
	int second;
public:

	//Judging the input datas whether is validate.
	void validate() const;

	//input datas to the CTime's data members
	void input();

	//count the current time's next second time
	void nextSecond();

	//count the current time's next 100 days' time 
	void next100days();

	//output datas
	void output() const;

	//carry bit for minute if minute is bigger than sixty
	void minuteAdvance();

	//carry bit for second if second is bigger than sixty
	void secondAdvance();

	//carry bit for hour if hour is bigger than twenty-four
	void hourAdvance();

	//carry bit for month if month can be added one 
	bool dayAdvance();

	//carry bit for year if year can be added one
	void monthAdvance();

	//bool isLearYear() const;
};


///////////////////////////////////////
void CTime::secondAdvance()
{
	if (second == 60)
	{
		second = 0;
        minute += 1;
	}	
}
///////////////////////////////////////
void CTime::minuteAdvance()
{
	if (minute == 60)
	{
		hour += 1;
		minute = 0;
	}
}
////////////////////////////////////////
void CTime::hourAdvance()
{
	if (hour == 24)
	{
		day += 1;
		hour = 0;
	}
}
//////////////////////////////////////////
bool CTime::dayAdvance()
{
	switch (month)
	{
	case 1: case 3: case 5: case 7:
	case 8: case 10: case 12:
		if (day > 31)
		{
			day -= 31;
			month += 1;
			return true;
		}
	case 4: case 6: case 9: case 11:
		if (day > 30)
		{
			day -= 30;
			month +=1;
			return true;
		}
	case 2:
		if ((year % 4 == 0 && year % 100) || (year % 400 == 0))
		{
			if (day > 29)
			{
				day -= 29;
				month += 1;
				return true;
			}
		}
		else 
		{
			if (day > 28)
			{
				day -= 28;
				month += 1;
				return true;
			}
		}
	}
	return false;
}
/////////////////////////////////////////
void CTime::monthAdvance()
{
	if (month >= 12)
	{
		month -= 12;
		year += 1;
	}
}
/////////////////////////////////////////
void CTime::output() const
{
	cout << year << "-" << month << "-" << day << ((hour >= 10) ? " " :  " 0") 
		 << hour << ":" << ((minute >= 10) ? "" :  "0")  << minute << ":" 
		 << ((second >= 10) ? "" :  "0")  << second << endl;
}


void CTime::validate() const
{
	assert(year >= 1);
	assert(month >= 1 && month <= 12);
	assert(day >= 1 && day <= 31);
	assert(hour >= 0 && hour <= 23);
	assert(minute >= 0 && minute <= 59);
	assert(second >= 0 && second <= 59);
}

void CTime::input()
{
	cout << "year month day hour minute second:" << endl;
	cin >> year >> month >> day >> hour >> minute >> second;

	validate();
}

void CTime::nextSecond()
{
	second += 1;
	secondAdvance(); //handle second
    minuteAdvance();//
    hourAdvance();
	dayAdvance();
	monthAdvance();
}

void CTime::next100days()
{
	day += 100;
	while (dayAdvance())
	{
		monthAdvance();
	}	
}

int main()
{	
	CTime time;

	time.input();
	cout << endl;
    CTime temp(time);
///////////////////////////////////////////////
	cout << "next second is :" << endl;
	time.nextSecond();
    time.output();
    cout << endl;

	CTime newTime(temp);
///////////////////////////////////////////////
	newTime.next100days();
	cout << "next 100 days is :" << endl;
	newTime.output();
	cout << endl;
	return 0;
}

目录
相关文章
|
6月前
|
数据库 时序数据库
时间里的T和Z都是什么
【6月更文挑战第24天】时间里的T和Z都是什么
152 0
|
7月前
|
XML Java 调度
什么是时间轮?
时间轮是一种用于任务调度和时间管理的数据结构,尤其适合处理大量定时任务的场景,如网络服务器或实时系统。它由一个圆形数组构成,每个槽代表固定时间间隔,任务根据执行时间添加到相应槽。时间推进时,指针移动并执行到期任务。时间轮具有高效性和简单性,插入和删除操作接近常数时间复杂度。层级时间轮可扩展处理更大时间范围和精度。在Spring Boot中,可以使用Netty的`HashedWheelTimer`实现高效定时任务管理。
119 0
|
Unix Linux Android开发
时间问题
时间问题
151 0
|
消息中间件 算法 Linux
什么是时间轮
什么是时间轮
372 0
建立时间与保持时间
建立时间(Set up time,简写为T s u T_{su}T su ​ )是指触发时钟沿(以上升沿为例)到达D触发器之前,要求输入信号必须已经达到稳定的时间。对应的,保持时间(Hold time,简写为T h T_hT h ​ )是指触发时钟沿到达D触发器之后,要求输入信号还需要保持必须稳定的时间。建立时间、保持时间相对于触发时钟沿的关系如图所示。输入信号在建立时间和保持时间不能发生变化,容易出现灾难。
287 0
建立时间与保持时间
别再用大小比较时间了
由于写代码习惯了基本数据类型(int/Integer、long等)大小的比较,很多人连Date的时间先后比较也用大小(>、<、>=、<=)了。
132 0
|
JavaScript 算法 前端开发
不到一秒才叫优化
之前做完的一个项目,业务逻辑写完之后,首屏渲染能到3~4秒,这对于用户体验是不能接受的,所以忙里偷闲把项目优化完之后http发送到响应时间:705ms,DOM构建完毕:452ms,页面加载完毕:678ms,清爽的感觉很上头~看来优化还是很有必要的!所以本篇记录一下优化过程。
247 0
如果时间可以倒流
今天同事问阿粉一个问题,觉得挺有意义的,在这里也问问各位读者们:如果时间可以倒流,你最想做什么呢?为什么呢? 这个问题阿粉也问了问身边的一些朋友们,下面是他们的答案,或许可以给你一些启发 朋友 A :如果时间可以倒流,我特别想要回到高中的时候,好好学习,踏踏实实的去努力,好好读书。不是那种死板教条的读书,是有计划有效率的读书,希望自己能够死不要脸一些,多向老师和同学请教问题,我可能天资不够聪慧,但是如果能够有效率一些,死不要脸一些,最起码会比现在要好得多吧
如果时间可以倒流
|
SQL JavaScript
时间问题,你会吗?
【本题考点】 1)涉及到多条件分组问题,要想到使用case when条件表达式。 2)时间问题,要想到常用的日期函数(datediff和timestampdiff)来解决。
时间问题,你会吗?
一些时间的处理
let BGT = $(o.beginT).val(); let EDT = $(o.endT).val(); spanAddCls(3); // 获取点击日期, let date = statis.
839 0