
C++走向远洋——50(Time类中的运算符重载、一目,二目比较运算符、二目赋值运算符、二目加减法运算符)
发布日期:2021-05-11 04:25:25
浏览次数:17
分类:精选文章
本文共 3797 字,大约阅读时间需要 12 分钟。
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhello * 完成日期:2016年5月17日 * 版本号:V1.0 * 问题描述:Time类中的运算符重载 * 程序输入:无 * 程序输出:见运行结果 */#includeusing 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); //二目的加减运算符的重载 //返回t规定的时、分、秒后的时间 //例t1(8,20,25),t2(11,20,50),t1+t2为19:41:15 CTime operator+(CTime &t); CTime operator-(CTime &t);//对照+理解 CTime operator+(int s);//返回s秒后的时间 CTime operator-(int s);//返回s秒前的时间 //二目赋值运算符的重载 CTime &operator+=(CTime &c); CTime &operator-=(CTime &c); CTime &operator+=(int s);//返回s秒后的时间 CTime &operator-=(int s);//返回s秒前的时间 //一目运算符的重载 CTime operator++(int);//后置++,下一秒 CTime &operator++();//前置++,下一秒 CTime operator--( int);//后置--,前一秒 CTime &operator--();//前置--,前一秒};CTime::CTime(int h,int m,int s){ hour=h; minute=m; second=s;}void CTime::setTime(int h,int m,int s){ hour=h; minute=m; second=s;}void CTime::display(){ cout< <<":"< <<":"< < (CTime &t) // 判断时间t1>t2{ if (hour>t.hour) return true; if (hour t.minute) return true; if (minute t.second) return true; return false;}bool CTime::operator <(CTime &t) //判断时间t1 t.hour) return false; if(minute t.minute) return false; if(second t) return false; return true;}bool CTime::operator <=(CTime &t) //判断时间t1<=t2{ if(*this =(CTime &t) //判断时间t1>=t2{ if(*this>t||*this==t) return true; return false;}bool CTime::operator !=(CTime &t) //判断时间t1!=t2{ if(*this==t) return false; return true;}//二目的加减运算符的重载CTime CTime::operator + (CTime &t) //t1+t2{ int h,m,s; s=second+t.second; m=minute+t.minute; h=hour+t.hour; if (s>59) { s-=60; m++; } if (m>59) { m-=60; h++; } while (h>23) h-=24; CTime t0(h,m,s); return t0;}CTime CTime::operator-(CTime &t) //t1-t2{ int h,m,s; s=second-t.second; m=minute-t.minute; h=hour-t.hour; if(s<0) { s+=60; m--; } if(m<0) { m+=60; h--; } if(h<0) h+=24; CTime t0(h,m,s); return t0;}//返回s秒后的时间CTime CTime::operator+(int s){ int ss=s%60; int mm=(s/60)%60; int hh=s/3600; CTime t0(hh,mm,ss); return *this+t0; //通过使用前面定义的运算符重载函数来减少代码数量}//返回s秒前的时间CTime CTime::operator -(int s){ int ss=s%60; int mm=(s/60)%60; int hh=s/3600; CTime t0(hh,mm,ss); return *this-t0;}//二目赋值运算符的重载CTime &CTime::operator+=(CTime &c){ *this=*this+c; return *this;}CTime &CTime::operator-=(CTime &c){ *this=*this-c; return *this;}//返回S秒后的时间CTime &CTime::operator+=(int s){ *this=+s; return *this;}//返回S秒前的时间CTime &CTime::operator -=(int s){ *this-=s; return *this;}//一目运算符的重载CTime CTime::operator++(int)//后置++,下一秒{ CTime t=*this; *this=*this+1; return t;}CTime &CTime::operator++()//前置++,下一秒{ *this=*this+1; return *this;}CTime CTime::operator--(int)//后置--,前一秒{ CTime t=*this; *this=*this-1; return t;}CTime &CTime::operator--()//前置--,前一秒{ *this=*this-1; return *this;}int main(){ CTime t1,t2,t; t1.setTime(5,12,12); t2.setTime(1,2,2); cout<<"下面比较两个时间大小:\n"; if (t1>t2) cout<<"t1>t2"< =t2) cout<<"t1≥t2"<
运行结果:
心得:
因为此程序的代码量较大,所以小毛病除了不少。其中在下面的代码中有一个疑问
bool CTime::operator <=(CTime &t) //判断时间t1<=t2{ if(*this=(CTime &t) //判断时间t1>=t2{ if(*this>t||*this==t) return true; return false;}
原来是:
bool CTime::operator <=(CTime &t) //判断时间t1<=t2{ if(*this<=t) return true; return false;}bool CTime::operator >=(CTime &t) //判断时间t1>=t2{ if(*this>=t) return true; return false;}
在运行时也不报错,但是每次运行到这里后程序就自动结束了。最后又改成上面那一段代码了,具体是怎么回事老师也没给出答案。。。。
发表评论
最新留言
逛到本站,mark一下
[***.202.152.39]2025年04月25日 04时37分52秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
leetcode题解538-把二叉搜索树转化为累加树
2025-04-05
leetcode题解56-合并区间
2025-04-05
leetcode题解62-不同路径
2025-04-05
leetcode题解66-加一
2025-04-05
leetcode题解70-爬楼梯
2025-04-05
leetcode题解72-编辑距离
2025-04-05
leetcode题解75-颜色分类
2025-04-05
leetcode题解767-重构字符串
2025-04-05
leetcode题解77-子集
2025-04-05
leetcode题解77-组合
2025-04-05
leetcode题解776-旋转字符串
2025-04-05
leetcode题解8-盛最多水的容器
2025-04-05
leetcode题解976-三角形的最大周长
2025-04-05
leetcode题解98-验证二叉搜索树
2025-04-05
LeetCode题解【打家劫舍】(中等难度)
2025-04-05
Leetcode题解(二)
2025-04-05
left join on、where后面的条件的区别
2025-04-05
left join right inner join 区别
2025-04-05
leftjoin多个on条件_MySQL:left join 避坑指南
2025-04-05
legend2---开发日志3(thinkphp的入口目录是public的体现是什么)
2025-04-05