码迷,mamicode.com
首页 > 编程语言 > 详细

算法题之丢手绢问题

时间:2017-07-02 19:46:52      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:i+1   static   多少   count   for   span   开始   blog   system   

n个人围成一圈,顺序排号,从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来的多少号?

public class DiuShouJuan {
    public static void main(String[] args) {
        System.out.println(result(4));
    }
    public static int result(int n){
        boolean[] arr = new boolean[n];
        for (int i = 0; i < arr.length; i++) {
            arr[i] = true;
        }
        int leftCount = n;//报数的人数
        int countNum = 0;//要报的数
        int index = 0;//下标
        while(leftCount>1){
            if(arr[index]==true){
                countNum++;
                if(countNum==3){
                    countNum=0;
                    arr[index]=false;
                    leftCount--;
                }
            }
            index++;
            if(index==n)
                index=0;
        }
        int result=0;
        for (int i = 0; i < n; i++) {
            if(arr[i]==true)
                result = i+1;
        }
        return result;
    }
}

 

算法题之丢手绢问题

标签:i+1   static   多少   count   for   span   开始   blog   system   

原文地址:http://www.cnblogs.com/lxcmyf/p/7106852.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!