博客
关于我
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/

你可能感兴趣的文章
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>