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;

}

相关推荐
lifewange4 分钟前
代码托管平台
开发语言
yangyanping201085 分钟前
Go语言学习之配置管理库Viper
开发语言·学习·golang
橘子编程7 分钟前
UniApp跨端开发终极指南
开发语言·vue.js·uni-app
onlooker66668 分钟前
Claude code 源码学习
学习·ai编程·claude code
sinat_2554878112 分钟前
泛型:超级、扩展、列表·学习笔记
java·windows·学习·算法
冬至喵喵13 分钟前
构建 CLI 的 Python 框架:Typer技术介绍
开发语言·chrome·python
世人万千丶15 分钟前
Flutter 框架跨平台鸿蒙开发 - 鸿蒙护眼版本2048操作式游戏应用
学习·flutter·游戏·华为·harmonyos·鸿蒙
AbandonForce16 分钟前
STL list
开发语言·c++
水饺编程17 分钟前
第4章,[标签 Win32] :SysMets3 程序讲解05,水平滚动
c语言·c++·windows·visual studio
前端老石人18 分钟前
HTML 入门指南:从规范视角建立正确知识体系
开发语言·前端·html