Java实现约瑟夫环问题「建议收藏」

Java实现约瑟夫环问题「建议收藏」约瑟夫环(约瑟夫问题)是一个数学的应用问题:已知n个人(以编号1,2,3…n分别表示)围坐在一张圆桌周围。从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人又出列;依此规律重复下去,直到圆桌周围的人全部出列。/***@author16026**/importjava.util.ArrayList;importjava.util.List;

大家好,又见面了,我是你们的朋友全栈君。

约瑟夫环(约瑟夫问题)是一个数学的应用问题:已知n个人(以编号1,2,3…n分别表示)围坐在一张圆桌周围。从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人又出列;依此规律重复下去,直到圆桌周围的人全部出列。


/** * @author 16026 * */
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class Yue { 
   
    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);
        scanner.close();
    }

    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);
            }
        }
    }
}

这里写图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136223.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月3日 下午10:36
下一篇 2022年6月3日 下午10:46


相关推荐

  • phpstudy nginx配置_phpstorm配置php环境

    phpstudy nginx配置_phpstorm配置php环境前言:首先来了解一下nginx工作原理:https://blog.csdn.net/hguisu/article/details/8930668一.nginx实现php动态解析原理nginx是一个高性能的http服务器和反向代理服务器。即nginx可以作为一个HTTP服务器进行网站的发布处理,也可以作为一个反向代理服务器进行负载均衡。但需要注意的是:nginx本身并不会对php文…

    2026年2月17日
    5
  • oracle 存储过程

    oracle 存储过程

    2021年7月7日
    84
  • dhcp option 67_DHCP HOST

    dhcp option 67_DHCP HOST1)DHCP客户端在初始化时广播发送请求报文,这时的请求报文并不包含option82选项。2)DHCP中继代理将option82选项添加到接收到的请求报文尾部后中继转发给DHCP服务器。DHCPOPTION82选项的子选项1(代理电路ID)默认是DHCP客户端所连接的交换机的接口信息(VLan名加物理端口名),也可以由用户自己配置代理电路ID,option82选项的子选项2(代理远程ID)是DHCP中继设备本身的MAC地址。3)DHCP服务器收到DHCP中继设备转发的DHCP请求…

    2022年10月16日
    1
  • oracle 视图编辑保存,oracle 视图

    oracle 视图编辑保存,oracle 视图视图是一个抽象的概念 简单的说就是把表中的部分我们关注的内容保存一份出来到视图中 这样我们每次就不需要通过那么多字段的表去查询数据 只需要通过已经过滤出来的我们关系的数据中 视图中 取我们需要的数据 进一步说就是从一张大的表数据中抽离出来一部分我们关注的数据 这部分数据就是可以存放在视图中 向视图提供数据内容的语句为 SELECT 语句 可以将视图理解为存储起来的 SELECT 语句 oracle

    2026年3月19日
    2
  • cheerio中文文档

    cheerio中文文档这篇参考手册是对 cheerio 官方文档的中文翻译 cheerio 是 jquery 核心功能的一个快速灵活而又简洁的实现 主要是为了用在服务器端需要对 DOM 进行操作的地方简介让你在服务器端和 html 愉快的玩耍 varcheerio require cheerio cheerio load

    2026年3月18日
    3
  • Oracle与MySQL的区别 以及优缺点

    Oracle与MySQL的区别 以及优缺点Oracle 与 MySQL 的区别以及优缺点 MySQL 的特点 1 性能卓越 服务稳定 很少出现异常宕机 2 开放源代码无版本制约 自主性及使用成本低 3 历史悠久 社区和用户非常活跃 遇到问题及时寻求帮助 4 软件体积小 安装使用简单且易于维护 维护成本低 品牌口碑效应 5 支持多种 OS 提供多种 API 接口 支持多种开发语言 对流行的 PHP Java 很好的支持 MySQL 的缺点 1 MySQL 最大的缺点是其安全系统 主要是复杂而非标准 另外只有到调用 mysqladmin 来重读用户权限才会发生改变 2

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号