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;

}

相关推荐
wm10431 分钟前
代码随想录第十天 栈和队列
开发语言·python
Java后端的Ai之路11 分钟前
【Java教程】- 并发编程核心知识解读
java·开发语言·并发编程
Sheep Shaun17 分钟前
C++11核心特性详解:从右值引用到现代C++编程
开发语言·数据结构·c++·算法
Dontla21 分钟前
Mybatis Introduction (Java ORM Framework)
java·开发语言·mybatis
信码由缰23 分钟前
JExten:基于Java模块系统(JPMS)构建健壮的插件架构
java·开发语言·架构
Dxy123931021625 分钟前
Python使用Playwright入门教程:从环境搭建到实战应用
开发语言·python·playwright
呱呱巨基31 分钟前
Linux Ext系列文件系统
linux·c++·笔记·学习
云深麋鹿32 分钟前
三.栈和队列
开发语言·数据结构·c++·算法
爆打维c38 分钟前
01BFS算法(例题:网格传送门旅游)
c语言·c++·python·算法·leetcode·广度优先
zpedu1 小时前
给大家普及一下,1月才开始PMP的强度
学习