两个整数做除法,有时会产生循环小数,其循环部分称为:循环节。 比如,11/13=6=>0.846153846153… 其循环节为[846153] 共有6位。

题目描述:两个整数做除法,有时会产生循环小数,其循环部分称为:循环节。

比如,11/13=6=>0.846153846153... 其循环节为[846153] 共有6位。

下面的方法,可以求出循环节的长度。

java 复制代码
import java.util.Vector;
public class test3 {
    public static void main(String[] args) {
        System.out.println(f(11,13));
    }
    public static int f(int n,int m){
        n=n%m;
        Vector v=new Vector();
        for(;;){//无限循环
            v.add(n);//将每次的余数添加到数组中
            n*=10;//当前余数扩大10倍,求得下一位余数
            n=n%m;
            if(n==0)
                return 0;
                //如果当前的余数不是第一次出现,那么就说明已经循环节出现了
            if(v.indexOf(n)>=0)
            //为了避免循环部分是相同的数字的情况,因此需要减去第一次出现的位置
                return v.size()-v.indexOf(n);

            }
        }
    }

输出:

java 复制代码
6
相关推荐
超级大只老咪6 小时前
数组相邻元素比较的循环条件(Java竞赛考点)
java
hh随便起个名6 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
小浣熊熊熊熊熊熊熊丶6 小时前
《Effective Java》第25条:限制源文件为单个顶级类
java·开发语言·effective java
毕设源码-钟学长6 小时前
【开题答辩全过程】以 公交管理系统为例,包含答辩的问题和答案
java·eclipse
啃火龙果的兔子6 小时前
JDK 安装配置
java·开发语言
星哥说事6 小时前
应用程序监控:Java 与 Web 应用的实践
java·开发语言
派大鑫wink6 小时前
【JAVA学习日志】SpringBoot 参数配置:从基础到实战,解锁灵活配置新姿势
java·spring boot·后端
xUxIAOrUIII7 小时前
【Spring Boot】控制器Controller方法
java·spring boot·后端
Dolphin_Home7 小时前
从理论到实战:图结构在仓库关联业务中的落地(小白→中级,附完整代码)
java·spring boot·后端·spring cloud·database·广度优先·图搜索算法
等....7 小时前
Miniconda使用
开发语言·python