简单地求最大公约数

问题描述:输入两个正整数,求其最大公约数。实现多组数据输入

我学习不努力的表现之一就是课堂上老师讲的新知识记不住,因为不经常用,留在脑子里的是自己的想法。这不,这个问题每每遇到都是如下的解法,其实用递归才简单。

#include<stdio.h>
int digui(int max,int min)
{
    int left;
    while((left=max%min)!=0){//就是辗转相除的思想,当left等于0时,max能被min整除,min就是最大公约数;
        max=min;//否则,把原来的除数变成新的被除数,
        min=left;//把原来的余数变成新的除数,反复执行
    }
    printf("%d\n",min);
}
int main()
{
    int a,b,medie;
    while(scanf("%d%d",&a,&b)!=EOF){
        if(a<b){//保持a总是大于等于b的
            medie=a;
            a=b;
             b=medie;
        }
        digui(a,b);
    
    }
}
        
    用递归写代码似乎简单些 ,道理都是一样。

#include<stdio.h>
int digui(int max,int min)
{
    if(max%min==0)
      return min;
    else
      return digui(min,max%min);
}
int main()
{
    int a,b,medie;
    while(scanf("%d%d",&a,&b)!=EOF){
        if(a<b){
            medie=a;
            a=b;
             b=medie;
        }
    printf("%d\n",digui(a,b));
    
    }
}
        
    

 

转载于:https://www.cnblogs.com/laobanban/archive/2013/03/03/2941242.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值