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;

}

相关推荐
晨晖28 小时前
直接插入排序
c语言·数据结构·c++·算法
宋情写8 小时前
Java基础篇01-环境搭建+入门体验
java·开发语言
cike_y8 小时前
Mybatis-万能的Map&模糊查询
java·开发语言·mybatis·安全开发
郝学胜-神的一滴8 小时前
Linux的pthread_self函数详解:多线程编程中的身份标识器
linux·运维·服务器·开发语言·c++·程序人生
小立爱学习8 小时前
ARM64 指令 --- CCMP/CSEL
linux·c语言
HUST8 小时前
C 语言 第七讲:数组和函数实践:扫雷游戏
c语言·开发语言·数据结构·vscode·算法·游戏·c#
oioihoii8 小时前
C++高并发编程核心技能解析
开发语言·c++
玖剹8 小时前
字符串相关题目
c语言·c++·算法·leetcode
jimy18 小时前
程序崩溃free(): double free detected in tcache 2
linux·开发语言·数据结构·链表
秋邱8 小时前
Java面向对象进阶:封装、继承、多态的实现逻辑与实战案例
java·开发语言·后端·spring cloud·ar·restful