Time类中的运算符重载

/*
* 程序的版权和版本声明部分
* Copyright (c)2012, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称: object.cpp
* 作者:隋 鑫
* 完成日期: 2013年 4 月 19 日
* 版本号: v1.0
* 输入描述:无
* 问题描述:
* 程序输出:
*/

#include <iostream>
using namespace std;
class CTime
{private:
	unsigned short int hour;    // 时
	unsigned short int minute;  // 分
	unsigned short int second;  // 秒
 public:
	CTime(int h=0,int m=0,int s=0);
	//void setTime(int h,int m,int s);
	void display();
	//比较运算符(二目)的重载
	bool operator > (CTime &t);
	bool operator < (CTime &t);
	bool operator >= (CTime &t);
	bool operator <= (CTime &t);
	bool operator == (CTime &t);
	bool operator != (CTime &t);
	//二目运算符的重载
	CTime operator+(CTime &c2);//返回c所规定的时、分、秒后的时间,例t1(8,20,25),t2(11,20,50),t1+t2为:41:15
	CTime operator-(CTime &c2);//对照+理解
	CTime operator+(int s);//返回s秒后的时间
	CTime operator-(int s);//返回s秒前的时间
	//一目运算符的重载
	CTime operator++( int);//后置++,下一秒
	CTime operator++();//前置++,下一秒,前置与后置返回值不一样
	CTime operator--( int);//后置--,前一秒
	CTime operator--();//前置--,前一秒
	//赋值运算符的重载     
	//CTime operator+=(CTime &c);
	//CTime operator-=(CTime &c);
	//CTime operator+=(int s); 
	//CTime operator-=(int s); 
};
//下面实现所有的运算符重载代码。
//为简化编程,请注意通过调用已有函数,利用好各函数之间的关系
    CTime::CTime(int h,int m,int s)
	{
		hour=h;
		minute=m;
		second=s;
	}
    bool CTime::operator > (CTime &t)
	{
		if(hour>t.hour)
			return true;
		else if(hour==t.hour&&minute>t.minute)
			return true;
		else if(minute==t.minute&&second>t.second)
			return true;
		else
			return false;
	}
	bool CTime::operator < (CTime &t)
	{
		if(hour<t.hour)
			return true;
		else if(hour==t.hour&&minute<t.minute)
			return true;
		else if(minute==t.minute&&second<t.second)
			return true;
		else
			return false;
	}
	bool CTime::operator >= (CTime &t)
	{
		if(hour>=t.hour)
			return true;
		else if(hour==t.hour&&minute>=t.minute)
			return true;
		else if(minute==t.minute&&second>=t.second)
			return true;
		else
			return false;
	}
	bool CTime::operator <= (CTime &t)
	{
		if(hour<=t.hour)
			return true;
		else if(hour==t.hour&&minute<=t.minute)
			return true;
		else if(minute==t.minute&&second<=t.second)
			return true;
		else
			return false;
	}
	bool CTime::operator == (CTime &t)
	{
		if(hour==t.hour&&minute==t.minute&&second==t.second)
			return true;
		else
			return false;
	}
	bool CTime::operator != (CTime &t)
	{
		if(hour!=t.hour)
			return true;
		else if(minute!=t.minute)
			return true;
		else if(second!=t.second)
			return true;
		else
			return false;
	}
	CTime CTime::operator+(CTime &c2)
	{
		CTime c;
		c.second=second+c2.second;  
		c.minute=minute+c2.minute;
		
		if(c.second>59)
			c.second-=60;
		    c.minute++;
		c.hour=hour+c2.hour;
		if(c.minute>59)
		    c.minute-=60;
			c.hour++;	
		if(c.hour>23)
			c.hour-=24;
	  return c;	 
	}
	CTime CTime::operator-(CTime &c2)
	{
		CTime c;
		c.second=second-c2.second;
		c.minute=minute-c2.minute;
		if(c.second>59)
		    c.second+=60;
         	c.minute--;
			
		c.hour=hour-c2.hour;
		if(c.minute>59)
		    c.minute+=60;
			c.hour--;	
		
		if(c.hour>23)
			c.hour+=24;
	  return c;
	}
	CTime CTime::operator+(int s)
	{
		CTime c;
		c.second=second+s;
		c.minute=minute;
		c.hour=hour;
		if(c.second>59)
		    c.minute=c.minute+c.second/60;
		    c.second%=60;
		if(c.minute>69)
			c.hour=c.hour+c.minute/60;
		if(c.hour>23)
			c.hour%=24;
		return c;
	}
	CTime CTime::operator-(int s)
	{
		CTime c;
		c.second=second-s%60;
		c.minute=minute-s/60%60;
		c.hour=hour-s/3600%24;
		if(c.second>59)
			c.second+=60;
		    c.minute--; 
		if(c.minute>59)
			c.minute+=60;
			c.hour--;    
		if(c.hour>23)
			c.hour+=24;
		return c;
	}
	CTime CTime::operator++( int)
	{
		 CTime temp(*this);
		 second++;
		{
			if(second>=60)
			{
				second-=60;
				++minute;
			}
			else if(minute>=60)
			{
				minute-=60;
				++hour;
			}
			else if (hour>=24)
			    hour-=24;
		}
       return *this   ;
	}
		
	CTime  CTime::operator++()
	{
		{
			if(++second>=60)
			{
				second-=60;
				++minute;
			}
			else if(minute>=60)
			{
				minute-=60;
				++hour;
			}
			else if (hour>=24)
			    hour-=24;
		}
       return *this   ;
	}
	CTime CTime::operator--( int)
	{
		 CTime temp(*this);
		 second--;
		{
			if(second>=60)
			{
				second+=60;
				--minute;
			}
			else if(minute>=60)
			{
				minute+=60;
				--hour;
			}
			else if (hour>=24)
			    hour+=24;
		}
       return *this   ;
	}
	CTime CTime:: operator--()
	{
		{
			if(--second>=60)
			{
				second+=60;
				--minute;
			}
			else if(minute>=60)
			{
				minute+=60;
				--hour;
			}
			else if (hour>=24)
			    hour+=24;
		}
       return *this   ;
	}

	
	void CTime::display()
	{
		cout<<hour<<":"<<minute<<":"<<second<<endl;
	}

int main()
{
	CTime t1(8,20,25),t2(11,20,50),t;
	int s=500;
	cout<<"t1为:";
	t1.display();
	cout<<"t2为:";
	t2.display();
	cout<<"s为:"<<s<<"s"<<endl;
	cout<<endl;
	cout<<"下面比较两个时间大小:\n";
	if (t1>t2) cout<<"t1>t2"<<endl;
	if (t1<t2) cout<<"t1<t2"<<endl;
	if (t1==t2) cout<<"t1=t2"<<endl; 
	if (t1!=t2) cout<<"t1≠t2"<<endl;
	if (t1>=t2) cout<<"t1≥t2"<<endl;
	if (t1<=t2) cout<<"t1≤t2"<<endl;
	cout<<endl;
	t=t1+t2;
	cout<<"t1+t2=";
	t.display();
	t=t1-t2;
	cout<<"t1-t2=";
    t.display();
	cout<<endl;
	t=t1+s;
	cout<<"t1+s=";
    t.display();
	t=t2+s;
	cout<<"t2+s=";
    t.display();
	t=t1-s;
	cout<<"t1-s=";
    t.display();
	t=t2-s;
	cout<<"t2-s=";
    t.display();
	cout<<endl;
	t=t1++;
	cout<<"t1++=";
    t.display();
	t=t1--;
	cout<<"t1--=";
    t.display();
	t=t1--;
	cout<<"t1--=";
    t.display();
	t=t2--;
	cout<<"t2--=";
    t.display();
	t=++t1;
	cout<<"++t1=";
    t.display();
	t=++t2;
	cout<<"++t2=";
    t.display();
	t=--t1;
	cout<<"--t1=";
    t.display();
	t=--t2;
	cout<<"--t2=";
    t.display();
	cout<<endl;
	return 0;

}





运行结果:

weixin073智慧旅游平台开发微信小程序+ssm后端毕业源码案例设计 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
python017基于Python贫困生资助管理系统带vue前后端分离毕业源码案例设计 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值