/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:构建含有静态数据成员和成员函数的Time 类
* 作 者: 刘向一
* 完成日期: 2012 年 4 月3 日
* 版 本 号: V1.0
* 对任务及求解方法的描述部分
* 输入描述:
* 问题描述:
* 程序输出:
* 程序头部的注释结束
*/
#include <iostream>
using namespace std;
class Time
{
public:
Time(int=0,int=0,int=0);
void show_time( ); //根据is_24和from0,输出适合形式-20:23:5/8:23:5 pm/08:23:05 pm
void add_seconds(int); //增加n秒钟
void add_minutes(int); //增加n分钟
void add_hours(int); //增加n小时
static void change24(); //改变静态成员is_24,在12和24时制之间转换
static void changefrom0(); //改变静态成员from0,切换是否前导0
private:
static bool is_24; //为true时,24小时制,如20:23:5;为flase,12小时制,显示为8:23:5 pm
static bool from0; //为true时,前导0,8:23:5显示为08:23:05
int hour;
int minute;
int sec;
};
//下面写出静态成员的初始化及各成员函数的成员
bool Time::is_24=true;
bool Time::from0=false;
Time::Time(int h,int m,int s):hour(h),minute(m),sec(s){}
void Time::show_time( )
{
//显示时
int h=(is_24)?hour:(hour%12);
if(from0 && h<10) cout<<'0';
cout<<h<<":";
//显示分
if(from0 && minute<10) cout<<'0';
cout<<minute<<":";
//显示秒
if(from0 && sec<10) cout<<'0';
cout<<sec;
//确定显示am/pm
if(!is_24)
if(hour>12)
cout<<" pm";
else
cout<<" am";
cout<<endl;
}
void Time::change24()
{
is_24=!is_24;
}
void Time::changefrom0()
{
from0=!from0;
}
void Time::add_hours(int h) //增加n小时
{
hour+=h;
if (hour>23)
hour%=24;
}
void Time::add_minutes(int m) //增加n分钟
{
minute+=m;
if (minute>59) //参见add_seconds()中的注释
{
add_hours(minute/60);
minute%=60;
}
}
void Time::add_seconds(int s) //增加n秒钟
{
sec+=s; //直接加上去。此操作可能使sec超出取值范围,将在下面处理,我们只要保证此函数执行完sec的取值正确即可
if (sec>59) //注意:if中的两条语句不能交换顺序
{
add_minutes(sec/60); //增加sec/60分钟
sec%=60; //秒数应该是sec%=60
}
}
int main( )
{
Time t1(23,14,25),t2(8,45,6);
cout<<"24时制, 不前导0:"<<endl;
cout<<" t1是:";
t1.show_time();
cout<<" t2是:";
t2.show_time();
t1.add_hours(10);
t2.add_hours(10);
Time::changefrom0(); //注意此处调用静态成员
cout<<"10小时后, 切换是否前导0:"<<endl;
cout<< "t1是:";
t1.show_time();
cout<< "t2是:";
t2.show_time();
t1.change24();
cout<<"换一种制式:"<<endl;
cout<<" t1是:";
t1.show_time();
cout<<" t2是:";
t2.show_time();
system("pause");
return 0;
}