• 学生报数算法实现


    问题:100个小朋友围成一个圈,设定编号为1~100,依次按1,2,3,4,5,6,7,8,9循环报数,报到9的出圈,直到所有小朋友出圈.请写代码打印出各个小朋友出圈顺序,语言不限;

    分析:

            循环报数,需要一个值用来记录报数顺序;
            人设定了固定编号;
            顺序和学生编号无关;
     
    以下是java代码实现:
    package com.play.number;
    
    import java.util.ArrayList;
    import java.util.Iterator;
    import java.util.List;
    
    /**
    * @Description: 学生报数
    * @author 橙木鱼
    * @date 2018年4月11日 上午8:52:53
    */
    public class Number {
    
        public static void main(String[] args) {
            // 1 创建学生编号集合
            List<Integer> kids = new ArrayList<>();
            for (int i = 1; i <= 100; i++) {
                kids.add(i);
            }
            //2 返回的数据顺序集合
            List<Integer> sorts = new ArrayList<>();
            
            //3 计数常量 用于喊数
            int num = 0;
            
            //4 判断是否还有在喊数的学生
            while(kids.size()>0) {
                Iterator<Integer> iterator = kids.iterator();
                // 5 遍历学生集合
                while(iterator.hasNext()) {
                    Integer next = iterator.next();
                    num++;
                    // 6 获取喊到9的学生记录,并从圈中剔除
                    if(num%9==0) {
                        sorts.add(next);
                        iterator.remove();
                    }
                }
            }
            //7 输出报数顺序
            System.out.println(sorts);
        }
    }
     
    输出结果:
    [9, 18, 27, 36, 45, 54, 63, 72, 81, 90, 99, 8, 19, 29, 39, 49, 59, 69, 79, 89, 100, 11, 22, 33, 44, 56, 67, 78, 91, 2, 14, 26, 40, 52, 65, 77, 92, 4, 17, 32, 47, 61, 75, 88, 5, 21, 37, 53, 70, 85, 1, 20, 38, 57, 74, 94, 12, 31, 51, 73, 95, 15, 41, 62, 84, 7, 34, 60, 86, 13, 43, 71, 98, 30, 66, 97, 35, 76, 10, 50, 93, 42, 83, 28, 87, 48, 6, 68, 46, 23, 3, 96, 16, 25, 64, 55, 58, 24, 80, 82]
    

    php代码实现:

    <?php
    
    $arr=array();
    for($x=1;$x<=100;$x++)
    {
       $arr[$x]=$x;
    }
    
    $num=0;
    while(count($arr)>0)
    {
        foreach($arr as $key=>$value)
        {
            $num++;
            if($num%9==0){
                var_dump($value);
                unset($arr[$key]);
            }      
        }
    }
    
    
  • 相关阅读:
    NYOJ926(概率)
    无根树转有根树
    Codeforces Round #304 C(Div. 2)(模拟)
    hdu5878(枚举,打表)
    求一个矩阵的逆矩阵(用伴随矩阵求)
    求n阶方阵的值(递归)
    setw()函数
    快速幂计算(整数快速幂/矩阵快速幂)
    全文检索
    发送邮件
  • 原文地址:https://www.cnblogs.com/chengmuyu/p/8793450.html
Copyright © 2020-2023  润新知