现在的位置: 首页 > 综合 > 正文

HDU 2033

2018年01月17日 ⁄ 综合 ⁄ 共 863字 ⁄ 字号 评论关闭
Problem Description
HDOJ上面已经有10来道A+B的题目了,相信这些题目曾经是大家的最爱,希望今天的这个A+B能给大家带来好运,也希望这个题目能唤起大家对ACM曾经的热爱。
这个题目的A和B不是简单的整数,而是两个时间,A和B 都是由3个整数组成,分别表示时分秒,比如,假设A为34 45 56,就表示A所表示的时间是34小时 45分钟 56秒。
 

Input
输入数据有多行组成,首先是一个整数N,表示测试实例的个数,然后是N行数据,每行有6个整数AH,AM,AS,BH,BM,BS,分别表示时间A和B所对应的时分秒。题目保证所有的数据合法。
 

Output
对于每个测试实例,输出A+B,每个输出结果也是由时分秒3部分组成,同时也要满足时间的规则(即:分和秒的取值范围在0~59),每个输出占一行,并且所有的部分都可以用32位整数表示。
 

Sample Input
2 1 2 3 4 5 6 34 45 56 12 23 34
 

Sample Output
5 7 9 47 9 30
 

解题思路:

简单的模60的进位相加而已,比起来高精度加法来说更为简单了一些,要掌握其中进位的内涵,哦,对了,最高位不用模60了,一开始模了60,

送了个WA,,,用结构体的好处就是不会因为数组的倒序正序而把自己绕进去,,

代码:

# include<cstdio>
# include<iostream>
# include<cstring>

using namespace std;

int a[4];
int b[4];
int c[4];

typedef struct node
{
    int h;
    int m;
    int s;
}T;


int main(void)
{
    int t;cin>>t;
    while ( t-- )
    {
        T a,b;
        T c;
        cin>>a.h>>a.m>>a.s;
        cin>>b.h>>b.m>>b.s;

        c.s = ( a.s+b.s )%60;
        c.m = ( a.m+b.m )%60 + ( a.s+b.s )/60;
        c.h = ( a.h+b.h ) + ( a.m+b.m )/60;
        cout<<c.h<<" "<<c.m<<" "<<c.s<<endl;

    }


    return 0;
}

抱歉!评论已关闭.