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;

}

相关推荐
lly2024065 小时前
Redis 发布订阅
开发语言
A0_張張5 小时前
记录一个PDF盖章工具(PyQt5 + PyMuPDF)
开发语言·python·qt·pdf
巴拉巴拉~~5 小时前
Flutter 通用下拉选择组件 CommonDropdown:单选 + 搜索 + 自定义样式
开发语言·javascript·ecmascript
ZHang......5 小时前
LeetCode 1114. 按序打印
java·开发语言·算法
协同生态6 小时前
天锐绿盾新版注册机【仅用于个人学习,禁止其他用途】
学习
缺点内向6 小时前
如何在 C# 中重命名 Excel 工作表并设置标签颜色
开发语言·c#·excel
Cuby!6 小时前
【AFDM与信号处理:论文阅读】仿射频分复用:扩展OFDM以实现场景灵活性和弹性
论文阅读·笔记·学习·信息与通信·信号处理
Можно6 小时前
深入理解 JavaScript 函数:分类、特性与实战应用
开发语言·javascript
淼淼7636 小时前
工厂方法模式
开发语言·c++·windows·qt·工厂方法模式
Hui Baby6 小时前
全局事务入口感知子事务方法-TCC
java·开发语言·数据库