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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

©   /  2012-12-15 21:35  /  3595 人查看  /  18 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

这是我遇到的类似的题分享下

package com.itheima;
import java.util.*;
/**
* 第十题:有100个人围成一个圈,从1开始报数,报到14的这个人就要退出。
* 然后其他人重新开始,从1报数,到14退出。问:最后剩下的是100人中
* 的第几个人?
*/
public class Test10 {

        /**
         * @param args
         */
        public static void main(String[] args) {
                // TODO Auto-generated method stub                        
                    ArrayList first = new ArrayList();     //定义集合为first
                int number = 14;                        //每次报数的点
                for (int i=1;i<=100 ;i++ )  //在集合加入1~100
                {
                        first.add(i);
                }
                sop(first);
                sop(first.size());
                Count(first,number);                //开始计算
                sop(first);
                sop(first.size());
        }
        private static ArrayList Count(ArrayList arl,int num)
        {
                for (int x=arl.size(); x>=num; x--)//一次一次报数
                {
                        arl.remove(num-1);                                //每到14时踢掉一个
                        ArrayList changeCollection = new ArrayList();//定义另一个集合用来装下first中的前13个数
                        for (int a = 0;a<num-1 ;a++ )  //把first中的前13个数装在changeCollection中,并且删掉first内部的前13个数
                        {
                                changeCollection.add(arl.get(0));
                                arl.remove(0);
                        }
                        for (int a =0;a<num-1 ; a++)//把changeCollection中的数重新放入first中,并且放在最后
                        {
                                arl.add(changeCollection.get(a));
                        }
                }
                return arl;
         }
        public static void sop(Object obj){
                System.out.println(obj);
        }
}
                        // 输出结果:
                        // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21
                        // , 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39,
                        // 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58,
                        // 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77,
                        // 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96,
                        // 97, 98, 99, 100]
                        // 100
                        // [16, 29, 36, 39, 47, 55, 72, 74, 75, 80, 90, 91, 92]
                        // 13
                        // 最终剩下的人:16, 29, 36, 39, 47, 55, 72, 74, 75, 80, 90, 91, 92
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马