7-151 最大公约数

这是一个C++程序,用于读取输入的两个正整数并计算它们的最大公约数(GCD)。程序首先读取测试数据的组数,然后对每组数据进行处理,包括对负数的处理,并使用辗转相除法(欧几里得算法)来找到最大公约数。最后,程序将结果打印出来。
摘要由CSDN通过智能技术生成

分数 10

全屏浏览题目

切换布局

作者 usx程序设计类课程组

单位 绍兴文理学院

求两个正整数m,n的最大公约数(Greatest Common Divisor,简称GCD)。

输入格式:

首先输入一个正整数T,表示测试数据的组数,然后是T组测试数据。每组测试输入2个整数m,n (0<m,n<10^9)。

输出格式:

对于每组测试,输出m,n的最大公约数。

输入样例:

2
63 36
20 15

输出样例:

9
5
#include<stdio.h>
int main()
{
    long long int a=0,b=0,c=0;
    long long int max=0;
    int n=0;
    scanf("%d",&n);
    while(scanf("%lld %lld",&a,&b)!=EOF){
        
        if(a<0)
        a=-a;
    
    if(b<0)
        b=-b;
    
     if(a==0&&b==0)
        printf("1");
    
    else if(a==0&&b!=0)
        printf("%lld",b);
    
    else if(b==0&&a!=0)
        printf("%lld",a);
    
    else if(a==b)
        printf("%lld",a);
    
    else if(a!=b)
    {
        
        while (a%b!=0){
        c=a%b;
        a = b;
        b = c;
        }
        max=b;
        printf("%lld\n",max);
   }
        
    }
    
      
    return 0;
}


 

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@pon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值