[LeetCode][C++]分数到小数

分数到小数

给定两个整数,分别表示分数的分子 numerator 和分母 denominator,以字符串形式返回小数。

如果小数部分为循环小数,则将循环的部分括在括号内。

示例 1:
输入: numerator = 1, denominator = 2
输出: “0.5”

示例 2:
输入: numerator = 2, denominator = 1
输出: “2”

示例 3:
输入: numerator = 2, denominator = 3
输出: “0.(6)”


思路:

  1. 首先判断除数是否是0,是的话,返回空字符串。
  2. 判断结果是不是负数,如果是,需要在字符串ans第一位安排上负号“-”。
  3. 为了防止溢出,将被除数,除数转换为long long型,因为已经知道结果的符号了,可以将被除数,除数转换为long long型后直接取绝对值。
  4. 取出整数部分quo,判断余数rem是否为0,若是则直接返回ans+string(整数);否则继续判断小数部分,这时提前加上小数点 ans+"."。
    5.关于小数循环的判断,我们记录每次除完的整数部分和余数rem,并且将整数部分存在字符串s中,记录此时的余数rem对应于字符串s中的位置索引,即使用unordered_map记录<rem, ind>,若某一次,rem在 unordered_map中找到,即找了循环的位置。

代码:

class Solution {
public:
    string fractionToDecimal(int numerator, int denominator) {
        if(denominator==0)
            return "";
        string ans;
        if((numerator>0 && denominator<0 ) || (numerator<0 && denominator>0) )
            ans="-";
        long long num=abs(static_cast<long long>(numerator));
        long long den=abs(static_cast<long long>(denominator));        
        long long quo=num/den;   //商Quotient
        long long rem=num%den;    //余数remainder
        
        //整除
        ans=ans+to_string(quo);
        if(!rem) return ans;
                
        //不能整除,即含有小数
        ans+=".";
        unordered_map<long long, int> u_m;  //存储每个余数在s中对应的索引
        string s="";
        int pos=0;
        while(rem)
        {
            if(u_m.find(rem)!=u_m.end())
            {
                s.insert(u_m[rem],"(");
                s+=")";
                return ans+s;
            }
            u_m[rem]=pos++;
            s+=to_string((rem*10)/den); //记录当前小数位
            rem=(rem*10)%den;   //更新rem           
        }
        return ans+s;                   
    }
};

结果:
在这里插入图片描述

参考链接:
[1] spark-meng:Leetcode 166 分数到小数 C++

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值