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;

}

相关推荐
沐知全栈开发5 小时前
Perl 数据库连接
开发语言
优雅的潮叭5 小时前
c++ 学习笔记之 shared_ptr
c++·笔记·学习
am心6 小时前
学习笔记-用户下单
笔记·学习
森叶6 小时前
Java 比 Python 高性能的原因:重点在高并发方面
java·开发语言·python
微露清风6 小时前
系统性学习C++-第二十二讲-C++11
java·c++·学习
qq_316837756 小时前
uni.chooseMedia 读取base64 或 二进制
开发语言·前端·javascript
方圆工作室6 小时前
【C语言图形学】用*号绘制完美圆的三种算法详解与实现【AI】
c语言·开发语言·算法
小二·6 小时前
Python Web 开发进阶实战:混沌工程初探 —— 主动注入故障,构建高韧性系统
开发语言·前端·python
Lkygo6 小时前
LlamaIndex使用指南
linux·开发语言·python·llama
进阶小白猿6 小时前
Java技术八股学习Day20
java·开发语言·学习