2023.5.18编程一小时打卡

一、问题描述:

题目描述:定义一个时间类,小时和分钟是其两个私有成员数据。输入一个起始时间和一个结束时间(起始时间早于结束时间),通过运算符重载-(减号),计算这两个时间相隔多少分钟。说明:这两个时间在同一天之内,且采用24小时计时分式,即从00:00-23:59。

   输入格式: 测试输入包含若干测试用例,每个测试用例占一行。每个测试用例包括四个数,用空格间隔,每个数都是由两位数字组成,第一个数和第二个数分别表示起始时间的小时和分钟,第三个数和第四个数分别表示结束时间的小时和分钟。当读入一个测试用例是00 00 00 00时输入结束,相应的结果不要输出。

二、解题思路:

首先,定义一个时间类包含小时和分钟俩个私有成员数据,并对-运算符进行重载,最后编写一个计算相差分钟数的函数并对其进行输出。

三、代码实现:

 1 #include<iostream>
 2 using namespace std;
 3 class Time 
 4 {
 5 private:
 6     int hour,minute;
 7 public:
 8     Time(){}
 9     Time(int h,int m):hour(h),minute(m){}
10     Time operator-(Time &t)
11     {
12         Time a;
13         if(minute>=t.minute)
14         {
15             a.minute=minute-t.minute;
16             a.hour=hour-t.hour;
17         }
18         else if(minute<t.minute)
19         {
20             a.minute=60+minute-t.minute;
21             a.hour=hour-1-t.hour;
22         }
23         return a;
24     }
25     void display()
26     {
27         cout<<hour*60+minute<<endl;
28     }
29 };
30 int main() 
31 {
32     int h1,m1,h2,m2;
33     for(int i=0;;i++)
34     {
35         cin>>h1>>m1>>h2>>m2;
36         if(h1==0&&m1==0&&h2==0&&m2==0)
37             break;
38         Time t1(h1,m1),t2(h2,m2);
39         Time t3;
40         t3=t2-t1;
41         t3.display();
42     }
43 }

 

posted @ 2023-05-18 19:30  信2211-8李欣垚  阅读(37)  评论(0)    收藏  举报