博客
关于我
6-4 使用函数求最大公约数 (10分)
阅读量:809 次
发布时间:2019-03-24

本文共 803 字,大约阅读时间需要 2 分钟。

为了实现一个计算两个正整数最大公约数(GCD)的简单函数,我们可以使用欧几里得算法。该算法通过反复将较大的数替换为较小数与余数的差值,直到某个数变成0,剩下的较大的数即为GCD。这种方法高效且适用于所有正整数。以下是实现GCD的函数:

为了实现一个计算两个正整数最大公约数(GCD)的简单函数,我们可以使用欧几里得算法。该算法通过反复将较大的数替换为较小数与余数的差值,直到某个数变成0,剩下的较大的数即为GCD。这种方法高效且适用于所有正整数。下面是实现GCD的函数:
使用一个变量`p`表示余数。通过循环不断替换`x`和`y`的值,直到`y`变为0。循环结束后,剩下的`x`即为最大公约数。这种方法的时间复杂度是O(log(min(x, y))),非常高效。
```html
为了实现一个计算两个正整数最大公约数(GCD)的简单函数,我们可以使用欧几里得算法。该算法通过反复将较大的数替换为较小数与余数的差值,直到某个数变成0,剩下的较大的数即为GCD。这种方法高效且适用于所有正整数。下面是实现GCD的函数:
使用一个变量`p`表示余数。通过循环不断替换`x`和`y`的值,直到`y`变为0。循环结束后,剩下的`x`即为最大公约数。这种方法的时间复杂度是O(log(min(x, y))),非常高效。
```htmlint gcd(int x, int y) { int p; while (y > 0) { p = x % y; x = y; y = p; } return x;}
测试输入的最大公约数:- 输入:32 和72- 输出:8

另一个测试:

  • 输入:49 和180
  • 输出:1
```

转载地址:http://nwgkk.baihongyu.com/

你可能感兴趣的文章
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>