欧几里得算法

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
/// <summary>
/// 欧几里得算法(求两个正整数的最大公约数)
/// 右称:辗转相除法
/// 
/// 假如需要求 1997 和 615 两个正整数的最大公约数,用欧几里德算法,是这样进行的:
/// 1997 = 3  * 615 + 152
/// 615  = 4  * 152 + 7
/// 152  = 21 * 7   + 5
/// 7    = 1  * 5   + 2
/// 5    = 2  * 2   + 1
/// 2    = 2  * 1   + 0
///当被加的数为 0 时,就得出了 1997 和 615 的最大公约数 1。
///
/// </summary>
public class EuclideanAlgorithmScript : MonoBehaviour {

    public int Int_a;                   
    public int Int_b;

    private int _Int_Residue;               //余数(MOD)
    private int _Int_Result;                //商值

    /// <summary>
    /// 欧几里得算法
    /// </summary>
    public void OnClick_GetsTheGCD_Method()
    {
        //Debug.Log(GetGCD(Int_a, Int_b));
        Debug.Log("最大公约数是 : " + GetGCD(Int_a, Int_b));

    }

    /// <summary>
    /// 欧几里得算法
    /// </summary>
    /// <param name="a"></param>
    /// <param name="b"></param>
    /// <returns></returns>
    private int GetGCD(int a,int b)
    {
        if (a > b)
        {
            _Int_Result = a / b;                //获取商值
            _Int_Residue = a % b;               //获取余值
            if (_Int_Residue == 0)              //当余数为0时,则找到最大公约数
            {
                return b;                       //公约数为被除数
            }
            else
            {                                   //否则重新计算
                a = b;
                b = _Int_Residue;
                return GetGCD(a, b);
            }
        }
        else
        {
            _Int_Result = b / a;                //获取商值
            _Int_Residue = b % a;               //获取余值
            if (_Int_Residue == 0)              //当余数为0时,则找到最大公约数
            {
                return a;                       //公约数为被除数
            }
            else
            {                                   //否则重新计算
                b = a;
                a = _Int_Residue;
                return GetGCD(a, b);
            }
        }
    }

}

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值