117.info
人生若只如初见

C语言实现求最大公约数的三种方法

方法一:暴力枚举法

#include 
int gcd(int a, int b) {
int min = (a < b) ? a : b;
int max = (a > b) ? a : b;
for (int i = min; i >= 1; i--) {
if (min % i == 0 && max % i == 0) {
return i;
}
}
return 1;
}
int main() {
int a, b;
printf("请输入两个数:");
scanf("%d %d", &a, &b);
printf("最大公约数为:%d\n", gcd(a, b));
return 0;
}

方法二:辗转相除法

#include 
int gcd(int a, int b) {
while (b != 0) {
int temp = a % b;
a = b;
b = temp;
}
return a;
}
int main() {
int a, b;
printf("请输入两个数:");
scanf("%d %d", &a, &b);
printf("最大公约数为:%d\n", gcd(a, b));
return 0;
}

方法三:更相减损法

#include 
int gcd(int a, int b) {
if (a == b) {
return a;
}
int max = (a > b) ? a : b;
int min = (a < b) ? a : b;
return gcd(max - min, min);
}
int main() {
int a, b;
printf("请输入两个数:");
scanf("%d %d", &a, &b);
printf("最大公约数为:%d\n", gcd(a, b));
return 0;
}

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

推荐文章

  • c语言goto用法是什么

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

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

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

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

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

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

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

  • Asp Conn.execute的参数与返回值总结

    参数: CommandText: 表示要执行的 SQL 命令或存储过程的字符串。 CommandType: 表示 CommandText 的类型,可以是 Text(默认)或 StoredProcedure。 Parameters...

  • response.setContentType()参数以及作用详解

    response.setContentType()方法用于设置响应的内容类型。它接受一个字符串参数,表示要设置的内容类型,通常以MIME类型表示。
    作用: 设置响应的内容类型:...

  • 浅谈Linux信号机制

    Linux信号机制是进程间通信的一种方式,它用于向进程发送异步通知和中断请求。信号可以用于实现进程间的同步和通信,以及处理异常和错误情况。
    Linux中的信...

  • C语言goto语句简单使用详解

    goto语句是C语言中的一种控制语句,用于无条件地将程序的控制转移到指定的语句处。它的使用可以简化程序的逻辑结构,但同时也容易造成程序流程的混乱,因此在实际...