约瑟夫环问题

约瑟夫环问题是一个经典的数学和计算机科学问题。在这个问题中,有n个人围成一圈,从第一个人开始报数,报到m的人就退出圈子,然后下一个人继续从1开始报数,直到最后只剩下一个人。我们需要找出最后留下的人在原来的排名。

这个问题可以通过模拟整个过程来解决。我们可以创建一个链表来模拟这个过程,每次报到m的人就删除,然后继续报数直到只剩下一个人。最后剩下的人就是我们要找的答案。

这个问题的解决方案涉及到一些数学知识,比如循环移位和取模运算。约瑟夫环问题的一般解决方案是使用循环移位运算符和取模运算符来构建一个周期序列,然后通过周期序列来找出最后留下的人的位置。

题目:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。

bash 复制代码
package test5;

import java.util.Scanner;

public class Test1 {
    
    public static void main(String[] args) {

        int n = 10;
        int num = n;
        int numSum = 0;
        int index = 0;
        boolean arr[] = new boolean[n];
        for (int i = 0; i < n; i++) {
            arr[i] = true;
        }
        while (num > 1) {
           if(arr[index]==true) {
                numSum++;
                if (numSum == 3) {
                    arr[index] = false;
                    numSum = 0;
                    num--;
                }
            }
            index++;
            if (index == n) {
                index = 0;
            }
        }

        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == true) {
                System.out.println("最后剩下的是第" + (i + 1) + "位");
            }

        }
    }

}
相关推荐
硕风和炜25 分钟前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
upgrador40 分钟前
基础知识:C++ STL构造函数的左闭右开惯例及其实现原理
开发语言·c++
格子软件43 分钟前
2026年GEO贴牌代理:分布式多级分账状态机源码深度解构
java·vue.js·分布式·vue·geo
我是一颗柠檬1 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡
灯厂码农1 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法
yoothey2 小时前
报废审批流规则引擎设计——责任链模式完整实现
linux·开发语言·bash
geovindu2 小时前
python: Functional Options Pattern
开发语言·后端·python·设计模式·惯用法模式·函数式选项模式
wuyk5552 小时前
24. C 语言模块化:不是拆几个.c 文件那么简单
c语言·开发语言·stm32·单片机
梦梦代码精3 小时前
电商系统不是技术堆叠:LikeShop如何用分层Hold住复杂业务?
java·docker·代码规范
凯瑟琳.奥古斯特3 小时前
K次取反最大化数组和解法(力扣1005)
开发语言·c++·算法·leetcode·职场和发展