zoukankan      html  css  js  c++  java
  • 约瑟夫环问题

    package com.zxc.E;
    
    /**
     * Created by Administrator on 2018/1/30 0030.
     */
            import java.util.ArrayList;
            import java.util.List;
            import java.util.Scanner;
    
    public class Joseph {
        public static void main(String[] args) {
            Scanner scanner = new Scanner(System.in);
            System.out.print("请输入总人数:");
            int totalNum = scanner.nextInt();
            System.out.print("请输入报数的大小:");
            int cycleNum = scanner.nextInt();
            yuesefu(totalNum, cycleNum);
        }
    
        public static void yuesefu(int totalNum, int countNum) {
            // 初始化人数
            List<Integer> start = new ArrayList<Integer>();
            for (int i = 1; i <= totalNum; i++) {
                start.add(i);
            }
            //从第K个开始计数
            int k = 0;
            while (start.size() >0) {
                k = k + countNum;
                //第m人的索引位置
                k = k % (start.size()) - 1;
                // 判断是否到队尾
                if (k < 0) {
                    System.out.println(start.get(start.size()-1));
                    start.remove(start.size() - 1);
                    k = 0;
                } else {
                    System.out.println(start.get(k));
                    start.remove(k);
                }
            }
        }
    }
  • 相关阅读:
    Vivian's Problem UVA
    Prime k-tuple UVA
    M
    Make a Crystal UVA
    Cryptography Reloaded UVALive
    Gauss Prime UVA
    Discrete Square Roots UVALive
    The Bells are Ringing UVALive
    Huge Mods UVA
    指数循环节
  • 原文地址:https://www.cnblogs.com/television/p/8387309.html
Copyright © 2011-2022 走看看