C/C++编程学习 - 第5周 ⑤ 人见人爱A+B

题目链接

题目描述

相信大家很多人都是从 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;
}

猜你喜欢

转载自blog.csdn.net/qq_44826711/article/details/112909400