题目描述
相信大家很多人都是从 a+b 开始了 NOIP 的生涯的,希望这道题目可以唤起大家对 NOIP 的初心。
这道题目不是一道简单的 a+b ,而是给你两个时间,计算两个时间的和。
比如,假设 A 为 34 45 56,就表示 A 所表示的时间是 34 小时 45 分钟 56 秒。
输入格式
第一行输入一个整数 n (1 ≤ n ≤ 10),表示测试的组数。
接下来 n 行,每行有六个整数, ha,ma,sa,hb,mb,sb,分别表示 a b 对应的时间。
输出格式
输出 a+b 后的时间,也是由时分秒 3 部分组成,同时也要满足时间的规则(即:分和秒的取值范围在 0∼59)。
Sample Input
2
1 2 3 4 5 6
34 45 56 12 23 34
Sample Output
5 7 9
47 9 30
思路
时间相加 逢60进1,考虑用 % 和 / 运算
C语言代码:
#include<stdio.h>
int main()
{
long long h, m, s, hh, mm, ss, n;
scanf("%lld", &n);
while(n--)
{
scanf("%lld%lld%lld%lld%lld%lld", &h, &m, &s, &hh, &mm, &ss);
m += (s + ss) / 60; //秒数大于60就进一位
s = (s + ss) % 60; //秒取余
h += (m + mm) / 60; //分数大于60就进一位
m = (m + mm) % 60; //分取余
h = h + hh;
printf("%lld %lld %lld\n", h, m, s);
}
return 0;
}
C++代码:
#include<bits/stdc++.h>
using namespace std;
int main()
{
ios::sync_with_stdio(false);
int h1, h2, h3, m1, m2, m3, s1, s2, s3, x, n;
cin >> n;
while(n--)
{
cin >> h1 >> m1 >> s1 >> h2 >> m2 >> s2;
s3 = s1 + s2;
x = s3 / 60;
s3 %= 60;
m3 = m1 + m2 + x;
x = m3 / 60;
m3 %= 60;
h3 = h1 + h2 + x;
cout << h3 << " " << m3 << " " << s3 << endl;
}
return 0;
}
没有C语言基础的同学们,可以先学习一下C语言语法,我会整理好,后面发出来
我已经写好了,可以去C语言程序设计专栏看第一周的内容。