Leetcode: Fraction to Recurring Decimal

题目:
Given two integers representing the numerator and denominator of a fraction, return the fraction in string format.

If the fractional part is repeating, enclose the repeating part in parentheses.

For example,

Given numerator = 1, denominator = 2, return "0.5".
Given numerator = 2, denominator = 1, return "2".
Given numerator = 2, denominator = 3, return "0.(6)".

思路:
用一个map记录每一个余数,当出现重复的余数时,那么将会进入循环,两个重复余数之间的部分就是循环体。

C++代码:

class Solution
{
public:
    string fractionToDecimal(int numerator, int denominator)
    {
        if (numerator == 0) return "0";
        if (denominator == 0) return "";

        string result = "";
        //如果其中有一个数为负,反正结果添加负号
        if ((numerator < 0) ^ (denominator < 0)) result += "-";

        //给分子和分母取绝对值
        long long lnumerator= numerator;
        long long ldenominator = denominator;
        lnumerator = abs(lnumerator);
        ldenominator = abs(ldenominator);

        long long quotient = lnumerator / ldenominator;
        result += to_string(quotient);
        //给余数乘以10是为了后续计算余数的结果为整数
        long long remainder = lnumerator % ldenominator * 10;
        //如果余数为0,直接返回结果
        if (remainder == 0) return result;

        result += ".";
        unordered_map<long long, int> dictionary;//用于存储余数及其余数的下标
        while (remainder != 0)
        {
            //如果dictionary中存在这个余数
            if (dictionary.find(remainder) != dictionary.end())
            {
                int position = dictionary[remainder];
                string front = result.substr(0, position);
                string back = result.substr(position, result.length());
                return front + "(" + back + ")";
            }
            dictionary.insert({remainder, result.length()});
            quotient = remainder / ldenominator;//用短除法计算商
            result += to_string(quotient);
            remainder = remainder % ldenominator * 10;//得到余数并乘以10
        }
        return result;
    }
};

Java代码(因为这道题没有提供C#代码的测试,所以这里使用Java,两个语言的语法差异不是太大):

public class Solution {
    public String fractionToDecimal(int numerator, int denominator) {
        if (numerator == 0) return "0";
        if (denominator == 0) return "";

        StringBuilder result = new StringBuilder();
        //如果numerator和denominator中有一个为负数,则结果添加负号
        if ((numerator > 0) ^ (denominator > 0)) result.append("-");

        //给numerator和denominator取绝对值
        long lnumberator = numerator;
        long ldenominator = denominator;
        lnumberator = Math.abs(lnumberator);
        ldenominator = Math.abs(ldenominator);

        //计算整数部分
        long quotient = lnumberator /ldenominator;
        result.append(quotient);
        //余数乘以10是为了让后面余数部分的计算
        long remainder = lnumberator % ldenominator * 10;
        //如果余数为0直接返回result结果
        if (remainder == 0) return result.toString();

        result.append('.');
        Map<Long, Integer> dictionary = new HashMap<Long, Integer>();
        while (remainder != 0) {
            //如果dictionary中存在remainder的值,则说明小数部分出现循环
            if (dictionary.containsKey(remainder)) {
                int position = dictionary.get(remainder);
                String front = result.substring(0, position);
                String back = result.substring(position, result.length());
                return front + '(' + back + ')';
            }

            //将remainder添加到dictionary中(key为remainder,value为对应的在result中的位置),继续计算余数
            dictionary.put(remainder, result.length());
            quotient = remainder / ldenominator;
            result.append(quotient);
            remainder = remainder % ldenominator * 10;
        }

        return result.toString();
    }
}

Python代码:

class Solution:
    # @return a string
    def fractionToDecimal(self, numerator, denominator):
        if numerator == 0:
            return '0'
        if denominator == 0:
            return ''

        result = ''
        if (numerator > 0) ^ (denominator > 0):
            result = result + '-'

        pnumerator = abs(numerator)
        pdenominator = abs(denominator)

        quotient = pnumerator / pdenominator
        result = result + str(quotient)
        remainder = pnumerator % pdenominator * 10

        if remainder == 0:
            return result

        result = result + '.'
        map = {}
        while remainder != 0:
            if map.has_key(remainder):
                position = map[remainder]
                front = result[0: position]
                back = result[position: len(result)]
                return front + '(' + back + ')'

            map[remainder] = len(result)
            quotient = remainder / pdenominator
            result = result + str(quotient)
            remainder = remainder % pdenominator * 10
        return result

你可能感兴趣的:(LeetCode)