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;

}

相关推荐
风吹迎面入袖凉4 分钟前
【Redis】Redisson分布式锁原理
java·服务器·开发语言
A.A呐4 分钟前
【QT第五章】系统相关
开发语言·qt
Orange_sparkle8 分钟前
learn claude code学习记录-S02
java·python·学习
李白你好9 分钟前
Java GUI-未授权漏洞检测工具
java·开发语言
小郑加油10 分钟前
python学习Day1:python的安装与环境搭载
python·学习·小白记录,保姆式教程
leo__52025 分钟前
拉丁超立方抽样(Latin Hypercube Sampling, LHS)MATLAB实现
开发语言·matlab
sycmancia27 分钟前
Qt——Qt中的标准对话框
开发语言·qt
橙露43 分钟前
Python 对接 API:自动化拉取、清洗、入库一站式教程
开发语言·python·自动化
Omigeq1 小时前
1.4 - 曲线生成轨迹优化算法(以BSpline和ReedsShepp为例) - Python运动规划库教程(Python Motion Planning)
开发语言·人工智能·python·算法·机器人
2301_808414381 小时前
自动化测试的实施
开发语言·python