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语言goto用法是什么

    在C语言中,goto语句用于从一个位置跳转到另一个位置。它可以用于跳出循环、条件语句或者函数。goto语句的语法如下:
    goto label;
    ...
    label: //...

  • goto在c语言中的运用方法是什么

    goto 语句在 C 语言中允许程序从一个位置跳转到另一个位置。然而,在实际编程中,过度使用 goto 语句通常被认为是一种不好的编程实践,因为它可能导致代码结构混...

  • c语言堆和栈的区别是什么

    C语言中的堆和栈是两种不同的内存分配方式。 栈(Stack):栈是由编译器自动分配和释放的内存区域,用于存储局部变量和函数调用的上下文信息。栈的特点是先进后出...

  • C语言结构体数组怎么定义和使用

    在C语言中,可以通过定义结构体数组来存储多个具有相同数据类型的结构体对象。下面是定义和使用结构体数组的示例代码:
    #include // 定义一个结构体类型

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

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

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

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

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

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

  • qt如何在界面输出文字

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