第九周上机实践项目——++和--的前置和后置
来源:互联网 发布:虚拟机nat网络配置 编辑:程序博客网 时间:2024/05/22 15:23
/**程序的版权和版本声明部分:*Copyright(c)2013,烟台大学计算机学院学生*All rights reserved.*文件名称:八周的改进 *作者:刘中林*完成日期:2014年4月30日*版本号:v0.1*对任务及求解方法的描述部分:*输入描述:输入时间 *问题描述:++和--的前置和后置 *程序输入:输入时间*程序输出:计算后的结果 *问题分析:无*算法设计:重载的小综合 *我的程序:*/#include <iostream>using namespace std;class CTime{public: friend ostream&operator<<(ostream&,CTime&);//声明友元重载运算符"<<"函数 friend istream&operator>>(istream&,CTime&);//声明友元重载运算符">>"函数 CTime operator++(int);//后置++,下一秒 CTime operator++();//前置++,下一秒,前置与后置返回值不一样 CTime operator--(int);//后置--,前一秒 CTime operator--();//前置--,前一秒 CTime(int h=0,int m=0,int s=0); void setTime(int h,int m,int s); //二目的比较运算符重载 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为: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秒前的时间private: unsigned short int hour; // 时 unsigned short int minute; // 分 unsigned short int second; // 秒};//下面实现所有的运算符重载代码。//构造函数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;}ostream& operator<<(ostream& output,CTime &t){ int s1,s2; s1=t.second/60; t.second=t.second%60; t.minute=t.minute+s1; s2=t.minute/60; t.minute=t.minute%60; t.hour=t.hour+s2; t.hour=t.hour%24; output<<t.hour<<":"<<t.minute<<":"<<t.second<<endl; return output;}istream& operator>>(istream& input,CTime &t){ int a,b,c; input>>a>>b>>c; t.setTime(a,b,c); return input;}//自行编制用于测试的main()函数,有些结果不必依赖display()函数,提倡用单步执行查看结果CTime CTime::operator++(int){ CTime temp(*this); second++; if(second>=60) { second-=60; ++minute; } return temp;}CTime CTime::operator++(){ if(++second>=60) { second-=60; ++minute; } return *this;}CTime CTime::operator--(int){ if(--second<60) { second+=60; --minute; } return *this;}CTime CTime::operator--(){ if(--second<60) { second+=60; --minute; } return *this;}bool CTime::operator > (CTime &t){ if(hour>t.hour) return true; if(hour<t.hour) return false; if(minute<t.minute) return true; if(minute>t.minute) return false; if(second<t.second) return true; return false;}bool CTime::operator < (CTime &t){ if(hour<t.hour) return true; if(hour>t.hour) return false; if(minute>t.minute) return true; if(minute<t.minute) return false; if(second>t.second) return true; return false;}bool CTime::operator >= (CTime &t){ if(*this<t) return false; return true;}bool CTime::operator <= (CTime &t){ if(*this>t) return false; return true;}bool CTime::operator == (CTime &t){ if(*this>t||*this<t) return false; return true;}bool CTime::operator != (CTime &t){ if(*this==t) return false; return true;}CTime CTime::operator+(CTime &t){ int h,m,s; h=hour+t.hour; m=minute+t.minute; s=second+t.second; if(h>23) { h-=24; } if(m>59) { m-=60; h++; } if(s>59) { s-=59; m++; } CTime t0(h,m,s); return t0;}CTime CTime::operator-(CTime &t){ int h,m,s; h=hour-t.hour; m=minute-t.minute; s=second-t.second; if(h<0) { h+=24; } if(m<0) { m+=60; h--; } if(s<0) { s+=59; m++; } 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;}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;}CTime CTime::operator+=(int s)//返回s秒后的时间{ *this=*this+s; return *this;}CTime CTime::operator-=(int s)//返回s秒前的时间{ *this=*this-s; return *this;}//自行编制用于测试的main()函数,有些结果不必依赖display()函数,提倡用单步执行查看结果int main(){ CTime t1,t2,t; cout<<"请输入时间t1:"<<endl; cin>>t1; cout<<"请输入时间t2:"<<endl; cin>>t2; cout<<"t1="<<t1; cout<<"t2="<<t2; 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; cout<<"++t1="<<t; t=t1--; cout<<"--t1="<<t;cout<<"++t1后t1的值为:"<<t1; cout<<"t1--后t1的值为:"<<t1; t2++; cout<<"t2++后t2的值为:"<<t2; --t2; cout<<"--t2后t2的值为:"<<t2; return 0;}
*样例输出:
*心得体会:从此以后没有我只有我们。。
0 0
- 第九周上机实践项目——++和--的前置和后置
- 前置++和后置++的区别
- ++前置和后置的区别
- 前置++和后置++的区别
- 前置++和后置++的区别
- 前置++和后置++的区别
- 关于前置++和后置++
- ++前置和后置
- Java - 前置++和后置++
- 前置和后置++
- 前置++和后置++重载
- 区分++,--的前置和后置的情况
- 运算符前置++和后置++的重载
- 浅谈前置++和后置++的区别
- C++中前置++和后置++的区别
- (转)前置++和后置++的区别
- 前置递增和后置递增的区别
- 前置和后置++运算符的重载
- Linux下安装搜狗输入法
- HDOJ 2222
- 初次运行 Git 前的配置
- 【转】OSAL内存管理0
- HDU 3336
- 第九周上机实践项目——++和--的前置和后置
- Python 实现网络爬虫小程序
- Linux引导流程
- 简单的API应用
- HDOJ 1698
- POJ 3468
- 线段树求矩形面积并 扫描线+离散化
- POJ 1151
- POJ 2104