HDU 1713 相遇周期
2007年3月26日,在中俄两国元首的见证下,中国国家航天局局长孙来燕与俄罗斯联邦航天局局长别尔米诺夫共同签署了《中国国家航天局和俄罗斯联邦航天局关于联合探测火星-火卫一合作的协议》,确定中俄双方将于2009年联合对火星及其卫星“火卫一”进行探测。
而卫星是进行这些探测的重要工具,我们的问题是已知两颗卫星的运行周期,求它们的相遇周期。
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
写这道题花了两天时间,我的妈。很苦恼,先开始是题意不理解,搞成了高中的物理题。死活求不出来答案,看了看大佬的解析才发现这是让求两个分数的的最小公倍数的。我自己的笨思路是先将两个分数的分母通分,分子变化成相应得值。之后再找到两个分子的最小公倍数;最后变剩下一步了,就是求两个分数的分子与分母的最大公约数了;例如2/5 3/4;先化为8/20 15/20;再找到8 和15的最小公倍数120 这样对小公倍数就为120/20 找到分子分母的最大公约数为20 得相遇周期为6;
后来发现 这样还不如 一开始将两个分数都约到最简分式,找到两个分母最大公约数,如果为1则表示分母的最小公倍数为两个分母的乘积例如2/5 3/4 两个分母最大公约数为1 这样最小公倍数为其乘积20;但是这个二十最后仍然会被约掉,因为在找分子的最小公倍数时是这样操作的 :2*4/20 3*5/20 其分子最小公倍数为2和3的最小公倍数乘上4和5的最小公倍数得到120 ,原式为(2*3)*(4*5)/4*5所以 当两个数分母最小公约数是1时 则这两个数的最小公倍数为分子相乘(注:两个分数都为最简分式),当两个分数分母的最大公约数不是1时例如2/5 和3/10,求其最小公倍数的步骤为4/10 3/10,4*3/10 会发现为6/5 即原式2和3的最小公倍数/5和10的最大公约数 所以这样也就可以把题目的要求解决了 即 除得尽的输出整数,除不尽的输出最简分式;
接下来上代码。之所以用_int64型的是因为我得求对大公约数的方法有点笨,求出来需要很大的存储空间。下面注释的代码求最大公约数更为简便运用了递归的思想;其他的改为所有的_int64 改为int就可以了。
#include<stdio.h>
#include<math.h>
__int64 gcd(__int64 q,__int64 w){__int64 c;while(w) //一定要除数做条件,不能用余数作条件,因为余数没有初值。{ // int gcd(int x,int y)c=q%w; //if(y==0)q=w; //return x;w=c; //else} //return gcd(y,x%y);return q; //}
}
__int64 lcm(__int64 x,__int64 y)
{__int64 B;B=x*y/gcd(x,y);return B;
}int main()
{ int n;__int64 a,b,c,d,t,m,k;scanf("%d",&n);while(n--){scanf("%I64d/%I64d %I64d/%I64d",&a,&b,&c,&d);t=gcd(a,b);a=a/t;b=b/t;m=gcd(c,d);c=c/m;d=d/m;k=gcd(b,d);if(k==1){printf("%I64d\n",lcm(a,c));}else{printf("%I64d/%I64d\n",lcm(a,c),k);}}return 0;
}
HDU 1713 相遇周期相关推荐
- HDU 1713相遇周期(两个分数的lcm)
相遇周期 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- HDU 1713 相遇周期【这也算数学吗?】
相遇周期 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissi ...
- HDU 1713 相遇周期(求两个分数的最小公倍数)
相遇周期 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- 杭电1713相遇周期
相遇周期 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- HDOJ 1713 相遇周期 (最大公约数与最小公倍数)
最大公约数函数模板 View Code 1 __int64 gcd(__int64 a,__int64 b) 2 { 3 return b==0? a:gcd(b,a%b); 4 } 相遇周期 Tim ...
- 杭电ACM 1713 相遇周期
相遇周期 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- 杭电oj(Java版)——1713 相遇周期
相遇周期 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- 相遇周期 HDU - 1713
2007年3月26日,在中俄两国元首的见证下,中国国家航天局局长孙来燕与俄罗斯联邦航天局局长别尔米诺夫共同签署了<中国国家航天局和俄罗斯联邦航天局关于联合探测火星-火卫一合作的协议>,确定 ...
- G - 相遇周期 HDU - 1713
添加链接描述 我们的问题是已知两颗卫星的运行周期,求它们的相遇周期. Input 输入数据的第一行为一个正整数T, 表示测试数据的组数. 然后是T组测试数据. 每组测试数据包含两组正整数,用空格隔开. ...
最新文章
- R语言ggplot2可视化分组的重叠图实战:grouped overlay plot
- 只要200行JavaScript代码,就能把特斯拉汽车带到您身边
- Jmeter 场景设计
- Java环境搭建若干问题
- qt坐标系统与布局的简单入门
- Python中的分片和索引方法
- 852 -山脉阵列中的峰值指数
- wpf silverlight的Behavior
- qsort和sort的区别
- java后端尝试使用WebOffice在线编辑
- 苹果手机连接Wifi认证机制
- 计算机字节与位的换算,计算机字节换算(计算机字节换算器)
- pyTorch常用工具包
- java前台显示后台数据_Thymeleaf在后台获取数据在前台显示
- 阿里云打造离线下载服务器
- Top10 ProxyClient 支持指定进程的代理客户端软件
- 整理的java基础知识点笔记
- Jetson Nano从零开始(2):硬件篇
- 腿麻脚软警告,体虚者勿入!
- C语言初步入门学习大略
热门文章
- ‘XXX‘ is defined but never used解决方法
- 【笔记】LaTeX数学公式
- 根文件系统制作 -- Kernel panic - not syncing
- RV1126 Linux AP6256调试、WIFI热点扫描
- 【软件测试】入门答疑,概念
- 根据经纬度坐标查看百度地图位置
- vue-video-player文档_【视频组件】vue-video-player的使用
- python xlsx 样式 谷歌开源 样式_连续加班一周最终把所有的Python库整理出来了,愿各位早日学会Py-站长资讯中心...
- torch norm() Formalize()
- C# Solidworks二次开发:自动创建点位时需要注意的问题