简化C#中的分数

Jar*_*H20 4 c# math simplify fractions

我已经制作了一个添加和减去分数的控制台应用程序,我添加了一个简化的函数:

    public static Numbers Add(Numbers n1, Numbers n2)
    {
        int den1;
        int num1;
        int num2;
        int dsimp;
        int nsimp;
        int numtop;
        num1 = n1.Numerator * n2.Denominator;
        num2 = n2.Numerator * n1.Denominator;
        den1 = n1.Denominator * n2.Denominator;
        numtop = num2 + num1;

        if (numtop == 0)
        {
            return new Numbers(0);
        }
        if (numtop % n1.Denominator == 0)
        {
            nsimp = numtop / n1.Denominator;
            dsimp = den1 / n1.Denominator;
            return new Numbers(nsimp, dsimp);

        }

        else
        {
            return new Numbers(numtop, den1);
        }
    }
Run Code Online (Sandbox Code Playgroud)

当我输入1/2 + 4/8时,它完全按照我告诉它的方式简化它,但是,它给了我8/8.这需要简化为1/1.如何将其简化为已经简化为最低分数的部分?

lep*_*pie 8

将分子和分母除以分子和分母的GCD(最大公约数).

例如:

从12/8开始说.GCD是4.因此3/2.

  • 确实你需要找到GCD:http://en.wikipedia.org/wiki/Greatest_common_divisor (2认同)
  • 如果数字基于`BigInteger`,则有一个现有方法:http://msdn.microsoft.com/en-us/library/system.numerics.biginteger.greatestcommondivisor.aspx for GCD (2认同)