117.info
人生若只如初见

C语言求最大公约数的方法有哪些

C语言求最大公约数的方法有以下几种:

  1. 辗转相除法:即用较大的数除以较小的数,然后用余数代替较大的数,再用较小的数除以余数,直到余数为0为止,此时较小的数即为最大公约数。
int gcd(int a, int b) {
if (b == 0) {
return a;
}
return gcd(b, a%b);
}
  1. 更相减损法:即用较大的数减去较小的数,然后用差值代替较大的数,再用较小的数减去差值,直到两个数相等为止,此时相等的数即为最大公约数。
int gcd(int a, int b) {
if (a == b) {
return a;
}
if (a > b) {
return gcd(a-b, b);
}
return gcd(a, b-a);
}
  1. 移位法:当a和b都是偶数时,2是它们的公约数,然后将a和b都右移1位,再继续求最大公约数,直到其中一个为0,此时另一个数即为最大公约数的2的幂倍。
int gcd(int a, int b) {
if (a == 0) {
return b;
}
if (b == 0) {
return a;
}
if ((a&1) == 0 && (b&1) == 0) {
return 2 * gcd(a>>1, b>>1);
}
if ((a&1) == 0) {
return gcd(a>>1, b);
}
if ((b&1) == 0) {
return gcd(a, b>>1);
}
if (a > b) {
return gcd(a-b, b);
}
return gcd(a, b-a);
}

这些方法都可以用于求两个整数的最大公约数。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fe69eAzsLBgBQAFc.html

推荐文章

  • C语言lseek()函数的用法是什么

    C语言中的lseek()函数用于在打开的文件中定位文件指针的位置。
    函数原型为:
    off_t lseek(int fd, off_t offset, int whence); 参数说明: fd:文件描...

  • c语言ln函数如何调用

    在C语言中,ln函数(自然对数函数)被定义在math.h头文件中。要调用ln函数,需要按照以下步骤: 包含math.h头文件:在程序中包含math.h头文件,这样才能使用其中...

  • c语言怎么让输出的数字间有空格

    在C语言中,你可以使用空格字符(’ ')来在数字之间添加空格。具体方法有以下几种: 使用printf函数的格式控制符:%d int num1 = 123;
    int num2 = 456;

  • c语言二维数组求和的方法是什么

    要求解一个二维数组的和,可以使用两个嵌套的for循环来遍历数组的每个元素,并将每个元素累加到一个变量中。下面是一个示例代码:
    #include #define ROWS 3...

  • shell怎么判断进程是否运行

    在shell中,可以使用以下命令来判断进程是否运行: 使用ps命令和grep命令结合,查找指定进程名的进程,并使用grep命令过滤结果。如果返回结果不为空,则进程正在...

  • linux捕获信号的方法是什么

    在Linux中,捕获信号的方法有两种: 使用信号处理函数:可以通过使用signal()函数来注册信号处理函数,该函数的原型如下: void (*signal(int sig, void (*handl...

  • 拨号服务器dns租用怎么配置

    要配置拨号服务器的DNS租用,可以按照以下步骤进行操作: 打开拨号服务器的网络设置界面,一般在操作系统的网络设置或网络连接选项中可以找到。 在网络设置界面中...

  • qt如何在界面输出文字

    在Qt中,可以使用QLabel组件来显示文字。具体操作如下: 在Qt的设计界面中,拖动一个QLabel控件到你想要显示文字的位置。 双击QLabel控件,进入编辑模式,将你想...