最大公约数和最小公倍数
/* 题目:输入两个正整数m和n,求其最大公约数和最小公倍数 程序分析: 1.最小公倍数=输入的两个数之积除于它们的最大公约数,关键是求出最大公约数; 2.求最大公约数用辗转相除法(又名欧几里德算法) 算法描述: 第一步:a ÷ b,令r为所得余数(0≤r 第二步:互换:置 a←b,b←r,并返回第一步 int main() { int a,b,t,r,n; printf("请输入两个数字:\n"); scanf("%d %d",&a,&b); if(a<b) {t=b;b=a;a=t;} r=a%b; n=a*b; while(r!=0) { a=b; b=r; r=a%b; } printf("这两个数的最大公约数是%d,最小公倍数是%d\n",b,n/b); return 0; } */ #include <stdio.h> int main() { int num1, num2, num3; int least = 1; int i; printf("输入两个正整数:"); scanf("%d %d", &num1, &num2); num3 = num1*num2; for (i = 2; i<=num1 && i<=num2; i++) { while (0==num1%i && 0==num2%i) { least *= i; num1 /= i; num2 /= i; } } printf("最大公约数:%d\n", least); printf("最小公倍数:%d\n", num3/least); return 0; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了