原题链接:[编程入门]最大公约数与最小公倍数
首先感谢指正,我的第一代代码考虑不全,虽然能过测试,但是出现特殊值就要完蛋。
这是我的第一代
#include<stdio.h> int main() { int a,b,t=1; scanf("%d %d",&a,&b);//输入两个数值 for(int i=1;i<=a&&i<=b;i++) { if(a%i==0&&b%i==0) { a/=i; b/=i; t*=i; } } printf("%d\n%d",t,a*b*t); return 0; }
看上去好像挺好,但问题在哪里呢?
比如我们输入18和36,i=1的时候,没问题,a=18 b=36 t=1。
i=2的时候,a=9 b=18 t=2。
i=3的时候,a=3 b=6 t=6。
问题就在i=4的时候,i=4大于a=3,非真,for循环判断条件过不了,那么就不会执行的语句。直接输出结果,6和108。
但很明显结果应该是18和36。
没办法,只能改。
#include<stdio.h> int main() { int a,b,x,y; scanf("%d %d",&a,&b);//输入两个数 a=a<b?a:b;//将a,b中更小的那个数赋值给a for(int i=1;i<=a;i++)//将所有满足条件的公约数全部列出来,最后一个肯定是最大的 { if(a%i==0&&b%i==0) { x=i; } } for(int i=b;i<=a*b;i++)//将所有满足条件的公倍数全部列出来 { if(i%a==0&&i%b==0) { y=i; break;//这个break很重要,我们只要最小公倍数,只要第一个出现的数就行,后面都不要 } } printf("%d\n%d",x,y); return 0; }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复