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;

}

相关推荐
sonnet-10291 天前
函数式接口和方法引用
java·开发语言·笔记
Bat U1 天前
JavaEE|多线程(二)
java·开发语言
今天你TLE了吗1 天前
LLM到Agent&RAG——AI概念概述 第二章:提示词
人工智能·笔记·后端·学习
烤麻辣烫1 天前
JS基础
开发语言·前端·javascript·学习
red_redemption1 天前
自由学习记录(168)
学习·已经运行中世界-模与约束·闭环
froginwe111 天前
C++ 文件和流
开发语言
Dxy12393102161 天前
Python在图片上画矩形:从简单边框到复杂标注的全攻略
开发语言·python
独自破碎E1 天前
面试官:你有用过Java的流式吗?比如说一个列表.stream这种,然后以流式去处理数据。
java·开发语言
꯭爿꯭巎꯭1 天前
python下载手机版(python3手机版(免费))
开发语言·python·智能手机
2601_954971131 天前
2026数学专业,靠什么技能能发挥数理优势转数据岗?
学习