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;

}

相关推荐
RSTJ_162514 分钟前
PYTHON+AI LLM DAY THREETY-NINE
开发语言·人工智能·python
赏金术士1 小时前
Kotlin 从入门到进阶 之函数模块(核心基础)(二)
android·开发语言·kotlin
HalvmånEver3 小时前
MySQL的索引
android·linux·数据库·学习·mysql
加号33 小时前
【Qt】 应用程序发布:依赖库拷贝与部署指南
开发语言·qt
金色光环3 小时前
【DSP学习】DSP28335 点亮LED
嵌入式硬件·学习·dsp开发
('-')3 小时前
八股复习2:Java Array list和Linked list
java·开发语言
我是发哥哈4 小时前
跨AI模型生成视频的五大维度对比:选型避坑指南
大数据·人工智能·学习·机器学习·chatgpt·音视频
小黄人软件4 小时前
C++读写编辑CSV文件示例源码 用于数据导入导出,比Excel好使
开发语言·c++·excel
郭涤生4 小时前
C++各个版本的性能和安全性总结
开发语言·c++
wljy15 小时前
二、静态库的制作和使用
linux·c语言·开发语言·c++