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;

}

相关推荐
我的xiaodoujiao几秒前
4、API 接口自动化测试详细图文教程学习系列4--相关Python基础知识3
python·学习·测试工具·pytest
C++ 老炮儿的技术栈1 分钟前
Qt 开发机器人客户端程序
c语言·开发语言·c++·windows·qt·机器人
Maguyusi2 分钟前
Debian13(trixie) 安装php8.5 php-fpm8.5
开发语言·php·lsky pro
马猴烧酒.2 分钟前
【面试八股|计算机网络】计算机网络常见面试题详解笔记
java·开发语言·网络·笔记·计算机网络·算法·面试
学机械的鱼鱼3 分钟前
【学习笔记】如何快速理解ROS2
笔记·学习
2401_833197736 分钟前
现代C++多线程编程实战
开发语言·c++·算法
red_redemption6 分钟前
自由学习记录(145)
学习
m0_587958957 分钟前
C++中的适配器模式实战
开发语言·c++·算法
醇氧7 分钟前
【学习】封锁协议
网络·学习·oracle
西门吹雪分身9 分钟前
JMM java内存模型分析
java·开发语言