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;

}

相关推荐
是苏浙11 小时前
零基础入门C语言之C语言实现数据结构之顺序表应用
c语言·数据结构·算法
南汐汐月11 小时前
重生归来,我要成功 Python 高手--day33 决策树
开发语言·python·决策树
星释11 小时前
Rust 练习册 :Proverb与字符串处理
开发语言·后端·rust
工会主席-阿冰12 小时前
数据索引是无序时,直接用这个数据去画图的话,显示的图是错误的
开发语言·python·数据挖掘
麦麦鸡腿堡12 小时前
Java_TreeSet与TreeMap源码解读
java·开发语言
snakecy12 小时前
系统架构设计师学习大纲目录
学习·系统架构
gladiator+12 小时前
Java中的设计模式------策略设计模式
java·开发语言·设计模式
Lucifer__hell12 小时前
【python+tkinter】图形界面简易计算器的实现
开发语言·python·tkinter
im_AMBER12 小时前
React 15
前端·javascript·笔记·学习·react.js·前端框架
2301_8129148712 小时前
py day34 装饰器
开发语言·python