166. 分数到小数
难度:中等
给定两个整数,分别表示分数的分子 numerator
和分母 denominator
,以 字符串形式返回小数 。
如果小数部分为循环小数,则将循环的部分括在括号内。
如果存在多个答案,只需返回 任意一个 。
对于所有给定的输入,保证 答案字符串的长度小于 104
。
示例 1:
输入:numerator = 1, denominator = 2
输出:"0.5"
示例 2:
输入:numerator = 2, denominator = 1
输出:"2"
示例 3:
输入:numerator = 2, denominator = 3
输出:"0.(6)"
示例 4:
输入:numerator = 4, denominator = 333
输出:"0.(012)"
示例 5:
输入:numerator = 1, denominator = 5
输出:"0.2"
提示:
-2^31 <= numerator, denominator <= 2^31 - 1
denominator != 0
解答:
class Solution {
public String fractionToDecimal(int numerator, int denominator) {
if(numerator == 0) return "0";
StringBuilder ans = new StringBuilder();
if(numerator < 0 ^ denominator < 0) ans.append("-");
long dividend = Math.abs(Long.valueOf(numerator));
long divisor = Math.abs(Long.valueOf(denominator));
ans.append(String.valueOf(dividend / divisor));
long remainder = dividend % divisor;
if(remainder == 0) return ans.toString();
ans.append(".");
Map<Long, Integer> map = new HashMap<>();
while(remainder != 0){
if(map.containsKey(remainder)){
ans.insert(map.get(remainder), "(");
ans.append(")");
break;
}
map.put(remainder, ans.length());
remainder *= 10;
ans.append(String.valueOf(remainder / divisor));
remainder %= divisor;
}
return ans.toString();
}
}
参考自:
作者:LeetCode-Solution
链接:https://leetcode-cn.com/problems/fraction-to-recurring-decimal/solution/fen-shu-dao-xiao-shu-by-leetcode/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。