A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 906822773 中级黑马   /  2014-7-15 21:35  /  767 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

有100个人围成一个圈,从1开始报数,报到14的这个人就要退出。然后其他人重新开始,从1报数,到14退出。问:最后剩下的是100人中的第几个人?
我是每次第14个人退出后,下一个从1报数,最后的结果算的是92,不知道对不对,求高手指点,我写的代码如下。

import java.util.Arrays;

public class Test2 {

        /**
         * @param args
         */
        public static void main(String[] args) {
                // TODO Auto-generated method stub
                int n=100;
                boolean[]per=new boolean[n];
                for(int i=0;i<per.length;i++){
                        per[i]=true;
                }
                int t=0,len=per.length;
                while(len>1){
                        for(int i=0;i<per.length;i++){
                                if(per[i]){
                                        t++;
                                        //System.out.println("第"+(i+1)+"报的是"+":"+t);
                                        if(t==14){
                                                t=0;
                                                per[i]=false;
                                                len--;
                                        }
                                }
                        }
                }
        System.out.println("最后的情况:"+Arrays.toString(per));
                for(int i=0;i<per.length;i++){
                        if(per[i]){
                                System.out.println("原来第:"+(i+1));
                        }
                }
        }

}

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马