Problem G: 时间类的流插入、提取和递增、递减运算
来源:互联网 发布:北京楼盘数据 编辑:程序博客网 时间:2024/06/06 12:47
Problem G: 时间类的流插入、提取和递增、递减运算
Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 2162 Solved: 1337
[Submit][Status][Web Board]
Description
封装一个时间类Time,在类上重载以下运算符,使得main()函数能够正确运行。
流插入操作符“>>”,按照输入格式从标准输入读取三个整数:hh,mm,ss,分别表示时、分、秒,其值在int范围内。
流提取操作符“<<”;按照“hh:mm:ss”输出Time类的对象,不合法的时间输出“error!!!”。
前置自增运算符“++”:把时间对象的秒数加1并返回。
前置自减运算符“--”:把时间对象的秒数减1并返回。
后置自增运算符“++”:把时间对象的秒数加1,返回原值。
后置自减运算符“--”:把时间对象的秒数减1,返回原值。
以上4个自增、自减仅对合法的时间操作,并且不会产生不合法的时间。比如:
若原时间对象为“00:00:00”,自减运算后的对象为“23:59:59”;
若原时间对象为“23:59:59”,自增运算后的对象为“00:00:00”;
若原时间对象为“24:60:60”,自增或自减运算后对象仍为“24:60:60”。
函数调用格式见append.cc。
append.cc中已给出main()函数
Input
输入的第一个整数n,表示有n组测试数据,每组3个整数:hh,mm,ss,分别表示时、分、秒,其值都在int范围内。
Output
输出一张表:每列8个字符宽,两列之间有一个空格。
首先,输出一个表头:“++t --t t t-- t++ t ”,
其次,对应每组测试数据在一行内依次以下内容:
前置++、前置--、原值、后置--、后置++、原值。
若输入的日期合法,输出格式为“hh:mm:ss”,不足两位的输出需要前面补0。如果输入的时间不合法,则输出“error!!!”。格式见sample。
Sample Input
60 0 10 59 591 1 6023 0 023 59 5924 1 0
Sample Output
++t --t t t-- t++ t 00:00:02 00:00:01 00:00:01 00:00:01 00:00:00 00:00:0101:00:00 00:59:59 00:59:59 00:59:59 00:59:58 00:59:59error!!! error!!! error!!! error!!! error!!! error!!!23:00:01 23:00:00 23:00:00 23:00:00 22:59:59 23:00:0000:00:00 23:59:59 23:59:59 23:59:59 23:59:58 23:59:59error!!! error!!! error!!! error!!! error!!! error!!!
HINT
输出格式用头文件<iomanip>中流操作算子:
setw(w) :设置数据的输出宽度为w个字符
setfill(c):设置用字符c作为填充字符
left :设置输出左对齐
right :设置输出优对齐
Append Code
append.cc,
#include <iostream>#include <iomanip>using namespace std;class Time{private: int h,m,s; int flag;public: friend istream & operator >> (istream &is,Time &t) { is>>t.h>>t.m>>t.s; if(t.h>23||t.h<0||t.m>59||t.m<0||t.s>59||t.s<0) t.flag = 1; else t.flag = 0; return is; } friend ostream & operator << (ostream &os,const Time &t) { if(t.h*3600+t.m*60+t.s>=24*3600||t.h<0||t.s<0||t.m<0||t.m>59||t.s>59) {os<<"error!!!";} else {os<<setw(2)<<setfill('0')<<t.h<<":"<<setw(2)<<t.m<<":"<<setw(2)<<t.s;} return os; } Time & operator ++ () { if(h*3600+m*60+s >= 24*3600||h<0||s<0||m<0||m>59||s>59) return *this; else { flag=((h*3600+m*60+s)+1)%(24*3600); h=flag/3600; m=(flag-h*3600)/60; s=flag-h*3600-m*60; return *this; } } Time &operator --() { if(h*3600+m*60+s >= 24*3600||h<0||s<0||m<0||m>59||s>59) return *this; else { flag=((h*3600+m*60+s)-1+24*3600)%(24*3600); h=flag/3600; m=(flag-h*3600)/60; s=flag-h*3600-m*60; return *this; } } Time operator ++ (int ) { Time t = (*this); if(h*3600+m*60+s >= 24*3600||h<0||s<0||m<0||m>59||s>59) return t; else { flag=((h*3600+m*60+s)+1)%(24*3600); h=flag/3600; m=(flag-h*3600)/60; s=flag-h*3600-m*60; return t; } } Time operator --(int) { Time t = (*this); if(h*3600+m*60+s >= 24*3600||h<0||s<0||m<0||m>59||s>59) return t; else { flag=((h*3600+m*60+s)-1+24*3600)%(24*3600); h=flag/3600; m=(flag-h*3600)/60; s=flag-h*3600-m*60; return t; } }};int main(){ Time t; int cases; cin>>cases; cout<<setw(8)<<left<<"++t"<<" "; cout<<setw(8)<<left<<"--t"<<" "; cout<<setw(8)<<left<<"t"<<" "; cout<<setw(8)<<left<<"t--"<<" "; cout<<setw(8)<<left<<"t++"<<" "; cout<<setw(8)<<left<<"t"<<right<<endl; for(int i = 1; i <= cases; ++i) { cin>>t; cout<<(++t)<<" "; cout<<(--t)<<" "; cout<<t<<" "; cout<<t--<<" "; cout<<t++<<" "; cout<<t<<endl; }}
0 0
- Problem G: 时间类的流插入、提取和递增、递减运算
- Problem J: 时间类的流插入、提取和递增、递减运算
- 递增和递减运算符
- 递增和递减运算符
- C++ 递增/递减运算符和指针
- 运算符——递增++和递减--
- php递增、递减运算的理解
- (22)赋值运算符、递增和递减运算符
- for循环递增和递减的区别
- PHP -- 字符串的递增和递减
- 一个面试题,关于运算优先级和递增递减
- 第四章 4.5 递增和递减运算符
- 【C++学习笔记】递增/递减运算符和指针
- 后置递增和递减
- 后置递增和递减
- 递增、递减运算符位于变量前后的区别
- 运算符重载-流插入运算符和流提取运算符的重载
- 递增运算符&&递减运算符
- 关于ListView+checkbox+edittext错乱问题的总结
- jqueryrotate演示7种不同的旋转效果
- SpringBoot加载静态资源
- MyEclipse快捷键大全
- 关于“三天打渔两天晒网”的算法问题
- Problem G: 时间类的流插入、提取和递增、递减运算
- 排序之快速排序
- 文件系统:FAT16
- 用分号隔开多个关键字,在光标消失后自动处理
- 个人封装库,第一个版本(超烂)
- 二叉树的遍历(篇5)由中序和先序序列重建二叉树
- SQL面试问题及回答
- L1-007. 念数字 Java
- c++中 打开一个文件夹下的所有特定格式的文件(如JPG)