约瑟夫环问题是一个经典的数学和计算机科学问题。在这个问题中,有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) + "位");
}
}
}
}