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;

}

相关推荐
承渊政道14 小时前
Linux系统学习【深入剖析Git的原理和使用(下)】
linux·服务器·git·学习·gitee·vim·gitcode
沐知全栈开发14 小时前
Bootstrap 多媒体对象
开发语言
Hx_Ma1614 小时前
测试题(二)
java·开发语言
ShineWinsu14 小时前
对于C++中list的详细介绍
开发语言·数据结构·c++·算法·面试·stl·list
tackchen14 小时前
venv-manager 管理 Conda 环境 和 Python 虚拟环境 (venv)
开发语言·python·conda
lly20240614 小时前
ASP #include 指令详解
开发语言
海兰14 小时前
elasticsearch学习之基本概念-向量数据库
数据库·学习·elasticsearch
2501_9369603615 小时前
ROS快速入门杰哥教程1-77残缺版
java·开发语言
游乐码15 小时前
c#封装成员变量和成员方法和访问修饰符
开发语言·c#
weisian15115 小时前
JVM--13-深入ThreadLocal:线程私有数据的隔离艺术与实战陷阱
开发语言·jvm·threadlocal