HDU 1713相遇周期(未解决问题:递归和循环的效率问题,此题递归快)

相遇周期
Input
输入数据的第一行为一个正整数T, 表示测试数据的组数. 然后是T组测试数据. 每组测试数据包含两组正整数,用空格隔开。每组包含两个正整数,表示转n圈需要的天数(26501/6335,表示转26501圈要6335天),用’/'隔开。
Output
对于每组测试数据, 输出它们的相遇周期,如果相遇周期是整数则用整数表示,否则用最简分数表示。

分析:首先分别化简两个分数,除去最大公约数函数;
然后求出分子的最小公倍数作为最终结果的分子,
求出分母的最大公约数作为最终结果的分母;
最后化简所得结果,除去最大公约数函数;
输出;
代码:(所有的双等号都要删去其中空格)

Sample Input
2
26501/6335 18468/42
29359/11479 15725/19170
Sample Output
81570078/7
5431415

#include <stdio.h>
typedef long long LL; //type ok
/LL minbei(LL a, LL b)
{
LL max;
if(a>b)
max = a;
else
max = b;
for(;max<=a
b;max++)
if(max%a= =0 && max%b= =0)
break;
return max;
}
LL maxyue(LL a, LL b)
{
LL min;
if(a<b)
min = a;
else
min = b;
for(;min>0;min–)
{
if(a%min= =0 && b%min= =0)
break;
}
return min;
}*/

LL maxyue(LL a, LL b) {
if(b= =0)
return a;
else
return maxyue(b, a % b) ;
}
LL minbei(LL a, LL b) {
return a / maxyue(a, b) * b;
}
int main()
{
int T, tp;
LL t1, c1, t2, c2;
scanf("%d",&T);
for(;T–;)
{
scanf("%lld/%lld %lld/%lld",&t1, &c1, &t2, &c2);
tp = maxyue(t1, c1);
t1 = t1/tp;
c1 = c1/tp;
tp = maxyue(t2, c2);
t2 = t2/tp;
c2 = c2/tp;
t1 = minbei(t1, t2);
c1 = maxyue(c1, c2);
if(c1==1)
printf("%lld\n",t1);
else
printf("%lld/%lld\n",t1, c1);
}
return 0;
}
递归与循环:
1、不论是递归还是循环在运行过程中计算的次数是相同的,但是,对于不同的计算运行的时间却是有长有短。(比如说同样是计算使用位运算的时间就比四则运算的时间更长。)定义变量也要花时间。
https://blog.csdn.net/ccutyear/article/details/52819123

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值