博客
关于我
2019快手校招面试题循环小数
阅读量:251 次
发布时间:2019-03-01

本文共 466 字,大约阅读时间需要 1 分钟。

将分数a/b转换为小数形式的字符串表示时,可以按照以下步骤进行:

  • 处理整数部分:首先计算商res = a / b,余数remainder = a % b。如果remainder为0,则直接输出res。
  • 处理小数部分:如果余数不为0,进入循环处理小数部分。每次将余数乘以10,计算新的余数,并记录当前位的数字。
  • 记录余数位置:使用一个map记录每个余数及其出现位置。当余数重复出现时,确定循环开始的位置。
  • 处理循环部分:在余数重复时,输出非循环部分,小数循环部分用括号括起来。
  • 输出结果:根据处理情况,组合整数部分和小数部分,输出最终结果。
  • 以下是示例的处理过程:

    • 示例1:输入10和1,余数为0,直接输出10。
    • 示例2:输入1和2,余数为1。循环计算得小数部分为5,输出0.5。
    • 示例3:输入1和3,余数循环,输出0.(3)。
    • 示例4:输入1和6,余数循环开始于第二位,输出0.1(6)。
    • 示例5:输入1和7,余数循环开始于第1位,输出0.(142857)。

    通过模拟长除法并记录余数,可以准确判断是否进入循环,并正确分割输出结果。

    转载地址:http://fpev.baihongyu.com/

    你可能感兴趣的文章
    mysql中like % %模糊查询
    查看>>
    MySql中mvcc学习记录
    查看>>
    mysql中null和空字符串的区别与问题!
    查看>>
    MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
    查看>>
    MYSQL中TINYINT的取值范围
    查看>>
    MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
    查看>>
    Mysql中varchar类型数字排序不对踩坑记录
    查看>>
    MySQL中一条SQL语句到底是如何执行的呢?
    查看>>
    MySQL中你必须知道的10件事,1.5万字!
    查看>>
    MySQL中使用IN()查询到底走不走索引?
    查看>>
    Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
    查看>>
    MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
    查看>>
    mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
    查看>>
    mysql中出现Unit mysql.service could not be found 的解决方法
    查看>>
    mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
    查看>>
    Mysql中各类锁的机制图文详细解析(全)
    查看>>