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;

}

相关推荐
lightqjx13 分钟前
【C++】C++11 - Lambda表达式+包装器
开发语言·c++·c++11·lambda·包装器
BHXDML18 分钟前
操作系统实验:(七)动态分区分配方式的模拟
开发语言·数据库·操作系统
载数而行52020 分钟前
算法系列1之最小生成树
c语言·数据结构·c++·算法·贪心算法
重生之后端学习25 分钟前
208. 实现 Trie (前缀树)
java·开发语言·数据结构·算法·职场和发展·深度优先
清水白石00830 分钟前
从频繁“握手”到高效通行:Python 数据库连接池深度解析与调优实战
开发语言·数据库·python
我命由我1234531 分钟前
C++ EasyX 开发,MessageBox 函数参数问题:“const char *“ 类型的实参与 “LPCWSTR“ 类型的形参不兼容
c语言·开发语言·c++·后端·学习·visualstudio·visual studio
shehuiyuelaiyuehao36 分钟前
关于hashset和hashmap,还有treeset和treemap,四个的关系
java·开发语言
带你看月亮37 分钟前
Vue3解析学习 - handlers 模块
vue.js·学习
only-qi38 分钟前
Java 包装器模式:告别“类爆炸“
java·开发语言
Yweir39 分钟前
Java 接口测试框架 Restassured
java·开发语言