栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

(每日一题 day 002 - 模拟) 166. 分数到小数

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

(每日一题 day 002 - 模拟) 166. 分数到小数

文章目录
    • 题目
    • 题解

题目

题链:166. 分数到小数

题解

使用小学数学的长除法模拟解决,分三步走:

  1. 判断是否可以直接整除,可以整除直接相除返回结果即可
  2. 判断符号是否一正一负,是的话转为正数进行相除、并且结果记得添上负号。
  3. 小数方面的处理、使用一个hashmap判断是否存在循环小数、存在则加上括号、使用stringbulider的insert在出现重复余数的下标插入。没有最后会直接得到小数结果。
    需要注意的是在求余那一块可能会出现整形溢出的情况、所以改成long进行运算。
class Solution {
    public String fractionToDecimal(int numerator, int denominator) {
        long a = numerator,b = denominator;
        if (a%b == 0){
            return String.valueOf(a/b);
        }
        StringBuilder sb = new StringBuilder();
        if (a*b < 0){
            sb.append('-');
        }
        a = Math.abs(a);
        b = Math.abs(b);
        sb.append(a/b);
        sb.append('.');
        long rem = a%b;
        StringBuilder di = new StringBuilder();
        HashMap map = new HashMap<>();
        int i = 0;
        while (rem != 0 && !map.containsKey(rem)){
            map.put(rem,i++);
            rem *= 10;
            di.append(rem/b);
            rem = rem%b;
        }
        if (rem != 0){
            di.insert(map.get(rem),"(");
            di.append(')');
        }
        return sb.append(di.toString()).toString();
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/287358.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号