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

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

Leetcode 166. Fraction to Recurring Decimal

2019-11-11 02:10:37
字體:
來源:轉載
供稿:網友

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; }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临潭县| 常熟市| 溧水县| 徐州市| 吴江市| 临夏市| 苗栗县| 双峰县| 桓仁| 娄底市| 新化县| 博兴县| 卫辉市| 西峡县| 公主岭市| 聊城市| 浙江省| 蒲城县| 井冈山市| 抚松县| 藁城市| 紫阳县| 揭东县| 茶陵县| 施秉县| 河津市| 云阳县| 康马县| 民勤县| 凤翔县| 靖边县| 广东省| 余姚市| 鄯善县| 巨鹿县| 江北区| 新乐市| 镶黄旗| 定南县| 瑞丽市| 彩票|