C语言练习--给定两个数 ,取最大公约数

给定两个数 ,取最大公约数

暴力求解 效率低

int main()

{

int a = 0;

int b = 0;

scanf("%d %d", &a, &b);

int min = (a < b) ? a : b;

int i = 0;

for (i = min; i > 0; i--)

{

if (a % i == 0 && b % i == 0)

{

printf("有公约数:>%d", i);

break;

}

}

return 0;

}

辗转相除法

int main()

{

int a = 0;

int b = 0;

int c = 0;

scanf("%d %d", &a, &b);

while (c=a%b)

{

a = b;

b = c;

}

printf("最大公约数为 % d",b);

return 0;

}

相关推荐
linux修理工2 小时前
使用codebuddy学习kafka
分布式·学习·kafka
xiaoshuaishuai83 小时前
C# 委托与事件
开发语言·c#
kmblack13 小时前
javascript计算年龄
开发语言·javascript·ecmascript
阿寻寻3 小时前
【人工智能学习260612-软件测试篇】小工具实现 [特殊字符] Prompt工程 + RAG思路 + API调用 + 自动化测试
人工智能·功能测试·学习·prompt
肖爱Kun3 小时前
STL标准模块库操作
开发语言·音视频
Song_da_da_3 小时前
C# 接口(Interface)深度解析:规范、解耦与灵活扩展
开发语言·c#
吃好睡好便好3 小时前
白发的根源和应对
学习·生活
政沅同学3 小时前
基于 C# WPF + HALCON 的工业视觉算法工具框架(开源)
开发语言·c#·wpf
自然语3 小时前
基于场景、需求、方法匹配和学习评价的垂直移动任务控制系统
学习
影寂ldy3 小时前
C#WinForm 窗体基础(入口、部分类、属性、生命周期事件)
开发语言·c#