java使用队列解决约瑟夫环问题。写代码
时间: 2024-03-24 21:37:15 浏览: 86
java解决约瑟夫环问题
好的,以下是使用队列解决约瑟夫环问题的 Java 代码:
```java
import java.util.LinkedList;
import java.util.Queue;
public class JosephusProblem {
public static void main(String[] args) {
int n = 10; // 总人数
int m = 3; // 报数为3的人出列
josephus(n, m);
}
/**
* 使用队列解决约瑟夫环问题
* @param n 总人数
* @param m 报数为m的人出列
*/
public static void josephus(int n, int m) {
// 初始化队列
Queue<Integer> queue = new LinkedList<>();
for (int i = 1; i <= n; i++) {
queue.offer(i);
}
// 开始出列
int count = 1;
while (!queue.isEmpty()) {
int cur = queue.poll();
if (count % m == 0) {
System.out.print(cur + " ");
} else {
queue.offer(cur);
}
count++;
}
}
}
```
在上述代码中,我们使用了 Java 中的 LinkedList 实现了一个队列,然后按照约瑟夫环的规则进行出列操作,最终得到了解决约瑟夫环问题的结果。
阅读全文