1 Star 0 Fork 0

xiangxiang/LeetCode-NOTES

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
solution.cpp 1.69 KB
一键复制 编辑 原始数据 按行查看 历史
默然 提交于 7年前 . update all algorithms.
class Solution {
public:
string fractionToDecimal(int numerator, int denominator) {
return Helper(numerator, denominator);
}
string Helper(long long numerator, long long denominator)
{
//convert to 64_int in case INT_MIN/-1 overflow
//special case
if(denominator == 0)
return "";
else if(numerator == 0)
return "0";
string ret = "";
if((numerator<0) ^ (denominator<0))
{//one of them is negative, with bit or
ret += '-';
numerator = abs(numerator);
denominator = abs(denominator);
}
//integer part
if(numerator/denominator == 0)
//integer part is 0
ret += '0';
else
{
long long quotient = numerator/denominator;
ret += std::to_string(quotient);
if(numerator%denominator == 0)
//divisible
return ret;
else
//not divisible, numerator as remainder
numerator -= (quotient*denominator);
}
//decimal part
ret += '.';
string demical;
map<long long, int> m; //<remainder, index> pair
long long r = numerator;
while(r)
{
if(m.find(r) != m.end())
{//remainder
ret.insert(m[r], 1, '('); //insert (iterator p, size_t n, char c);
ret += ')';
break;
}
m[r] = ret.size();
r *= 10; //next digit
ret += std::to_string(r/denominator);
r %= denominator;
}
return ret;
}
};
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/xiangxiang920/LeetCode-NOTES.git
git@gitee.com:xiangxiang920/LeetCode-NOTES.git
xiangxiang920
LeetCode-NOTES
LeetCode-NOTES
master

搜索帮助