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

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

Leetcode 166. Fraction to Recurring Decimal

2019-11-11 03:22:30
字體:
供稿:網(wǎng)友

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

class Solution {public: string fractionToDecimal(int numerator, int denominator) { //整數(shù)部分 //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; }};
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 南和县| 美姑县| 恭城| 樟树市| 苍山县| 南部县| 漳州市| 贺兰县| 台前县| 恭城| 岚皋县| 正定县| 始兴县| 临桂县| 文登市| 马鞍山市| 乐都县| 广河县| 惠州市| 怀来县| 雷波县| 普安县| 桐柏县| 丰原市| 佳木斯市| 深泽县| 阿克苏市| 鄂托克旗| 安阳县| 恩平市| 新建县| 安福县| 逊克县| 来安县| 温州市| 莒南县| 凭祥市| 会理县| 云浮市| 宕昌县| 塘沽区|