-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy path166.cpp
28 lines (24 loc) · 1.03 KB
/
166.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
class Solution {
public:
string fractionToDecimal(int numerator, int denominator) {
if(denominator == 0) return "";
if(numerator == 0) return "0";
bool negative = (numerator < 0) ^ (denominator < 0);
long long lnumerator = abs((long long)numerator);
long long ldenominator = abs((long long)denominator);
unordered_map<int,int> map;//<numerator,index>
string res = (negative ? "-" : "") + to_string(lnumerator / ldenominator) + (lnumerator % ldenominator ? "." : "");
lnumerator = lnumerator % ldenominator;
while(lnumerator && map.find(lnumerator) == map.end()){
map[lnumerator]=res.size();
lnumerator *= 10;
res = res + to_string(lnumerator / ldenominator);
lnumerator = lnumerator % ldenominator;
}
if(lnumerator){
int idx = map.find(lnumerator)->second;
res = res.substr(0,idx) + "(" + res.substr(idx) + ")";
}
return res;
}
};