博客
关于我
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 视图,视图更新删除
查看>>
MySQL 触发器
查看>>
mysql 让所有IP访问数据库
查看>>
mysql 记录的增删改查
查看>>
MySQL 设置数据库的隔离级别
查看>>
MySQL 证明为什么用limit时,offset很大会影响性能
查看>>
Mysql 语句操作索引SQL语句
查看>>
MySQL 误操作后数据恢复(update,delete忘加where条件)
查看>>
MySQL 调优/优化的 101 个建议!
查看>>
mysql 转义字符用法_MySql 转义字符的使用说明
查看>>
mysql 输入密码秒退
查看>>
mysql 递归查找父节点_MySQL递归查询树状表的子节点、父节点具体实现
查看>>
mysql 里对root及普通用户赋权及更改密码的一些命令
查看>>
Mysql 重置自增列的开始序号
查看>>
MySQL 高可用性之keepalived+mysql双主
查看>>
mysql-connector-java各种版本下载地址
查看>>
mysql-group_concat
查看>>
MySQL-【4】基本操作
查看>>
Mysql-丢失更新
查看>>
Mysql-事务阻塞
查看>>