国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Leetcode 166. Fraction to Recurring Decimal

2019-11-11 02:09:57
字體:
來源:轉載
供稿:網友

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)”.

s思路: 1. 這道題的難點,就是如何把循環小數找出來,即:開始的地方。例如:這里寫圖片描述 2. 把每次余數的值和對應的商的位置的映射關系存在map里,方便查詢! 3. 這種設計兩個數的interplay,很多trival case需要考慮,比如:兩個負數相除,-2147483648/-1就必須轉換成long才能做;又比如:一個正數除以一個負數,10/-3,則要把符號先考慮,然后轉換成絕對值再計算小數部分;還比如,一個小的正數除以一個大的負數,7/-12,由于正數部分為0,所以還只有比較除數和被除數的絕對值大小才能得到符號。如果不仔細,不考慮這些可能的特殊情況,調試就很痛苦!

class Solution {public: string fractionToDecimal(int numerator, int denominator) { //整數部分 //long long lnum=long(numerator),lden=long(denominator); long in=lnum/lden; string ipart=to_string(in);//bug:-2147483648/-1 if(lnum<0&&lden>0||lnum>0&&lden<0){ lnum=abs(lnum); lden=abs(lden); if(lnum<lden) ipart='-'+ipart; } lnum%=lden; string dpart; unordered_map<long,int> mm; int idx=0; while(lnum!=0&&!mm.count(lnum)){ mm[lnum]=idx++; lnum*=10; dpart+=to_string(lnum/lden); lnum%=lden; } if(lnum==0){ if(dpart.empty()) return ipart; return ipart+'.'+dpart; } int start=mm[lnum]; dpart=dpart.substr(0,start)+'('+dpart.substr(start,idx-start)+')'; return ipart+'.'+dpart; }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 武穴市| 柳河县| 化州市| 麻江县| 泸西县| 平塘县| 突泉县| 平定县| 开阳县| 池州市| 榆中县| 阿瓦提县| 永春县| 大余县| 岱山县| 鄂托克旗| 西盟| 林芝县| 宁远县| 商丘市| 景德镇市| 辛集市| 内乡县| 广河县| 利辛县| 万山特区| 资阳市| 阳泉市| 乌苏市| 北宁市| 新野县| 闸北区| 湾仔区| 洛浦县| 临潭县| 迁安市| 休宁县| 万山特区| 丰台区| 策勒县| 玛多县|