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;

}

相关推荐
人间乄惊鸿客几秒前
c++自记录
java·开发语言·c++
csbysj20203 分钟前
MySQL 删除数据表
开发语言
wjs20243 分钟前
R 语言中的数组(Array)
开发语言
蓝影灵3 分钟前
单体改微服务记录
java·开发语言
李少兄5 分钟前
Java 短路求值的优雅实践:用 `&&` 实现安全高效的批量操作控制
java·开发语言
deepin_sir6 分钟前
14 - 面向对象编程
开发语言·python
oddsand16 分钟前
AI应用开发学习步骤-java
java·人工智能·学习
莫***妞6 分钟前
2026年java后端开发还有未来吗? 就业形式如何?
java·开发语言
知识分享小能手6 分钟前
Flask入门学习教程,从入门到精通,Flask智能租房——列表页 知识点详解(7)
python·学习·flask
MC皮蛋侠客6 分钟前
C++17 多线程系列(一):线程基础——std::thread 完全指南
开发语言·c++·多线程