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;

}

相关推荐
后端小张34 分钟前
【JAVA 进阶】SpringMVC全面解析:从入门到实战的核心知识点梳理
java·开发语言·spring boot·spring·spring cloud·java-ee·springmvc
2301_7890156235 分钟前
C++:二叉搜索树
c语言·开发语言·数据结构·c++·算法·排序算法
帅那个帅2 小时前
PHP里面的抽象类和接口类
开发语言·php
咖啡の猫8 小时前
Python字典推导式
开发语言·python
leiming68 小时前
C++ vector容器
开发语言·c++·算法
SystickInt8 小时前
C语言 strcpy和memcpy 异同/区别
c语言·开发语言
CS Beginner9 小时前
【C语言】windows下编译mingw版本的glew库
c语言·开发语言·windows
FJW0208149 小时前
Python_work4
开发语言·python
JAY_LIN——89 小时前
指针-数组
c语言·排序算法
upper20209 小时前
【炒股学习】集合竞价
学习·区块链