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;

}

相关推荐
运维管理12 小时前
H3C交换机Hybrid端口配置与VLAN理解-学习
运维·网络·学习
kong790692813 小时前
Python核心语法-Matplotlib简介
开发语言·python·matplotlib
mjhcsp13 小时前
C++数位 DP解析
开发语言·c++·动态规划
Coder_Boy_13 小时前
Java高级_资深_架构岗 核心知识点——高并发模块(底层+实践+最佳实践)
java·开发语言·人工智能·spring boot·分布式·微服务·架构
小龙报13 小时前
【算法通关指南:数据结构与算法篇】二叉树相关算法题:1.二叉树深度 2.求先序排列
c语言·开发语言·数据结构·c++·算法·贪心算法·动态规划
yy.y--13 小时前
Java线程实现浏览器实时时钟
java·linux·开发语言·前端·python
yaoxin52112313 小时前
327. Java Stream API - 实现 joining() 收集器:从简单到进阶
java·开发语言
pyniu14 小时前
Elasticsearch学习
后端·学习·elasticsearch·搜索引擎
liliangcsdn14 小时前
IMPALA强化学习算法的学习和解读
学习·算法
蒸蒸yyyyzwd14 小时前
os八股学习笔记
笔记·学习