Problem G: 时间类的流插入、提取和递增、递减运算

来源:互联网 发布:北京楼盘数据 编辑:程序博客网 时间:2024/06/06 12:47

Problem G: 时间类的流插入、提取和递增、递减运算

Time Limit: 3 Sec  Memory Limit: 128 MB
Submit: 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
原创粉丝点击