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;

}

相关推荐
2301_800256111 分钟前
【人工智能引论期末复习】第4章 机器学习3-无监督学习
人工智能·学习·机器学习
星火开发设计5 分钟前
深入浅出HDFS:分布式文件系统核心原理与实践解析
大数据·数据库·hadoop·学习·hdfs·分布式数据库·知识
电子_咸鱼7 分钟前
Linux IPC 实战:管道与共享内存的使用场景 + 底层原理全剖析
linux·运维·服务器·开发语言·网络·vscode·qt
smile_5me8 分钟前
RK3588 csm400b调试记录
c语言·开发语言
刘孬孬沉迷学习8 分钟前
6G 六大应用场景
学习·5g·信息与通信·6g·5g nr·6g 应用场景
修炼室9 分钟前
在 Windows 上构建不占 C 盘的科研级 WSL 实验环境(Ubuntu 22.04)
c语言·windows·ubuntu
C_心欲无痕13 分钟前
JavaScript 常见算法与手写函数实现
开发语言·javascript·算法
王解14 分钟前
本地管理员
学习·ctf
客卿12315 分钟前
C语言实现数组串联--力扣冒险
c语言·开发语言·leetcode
知识分享小能手16 分钟前
Oracle 19c入门学习教程,从入门到精通,Oracle体系结构 —— 知识点详解(2)
数据库·学习·oracle