Java实现约瑟夫环:50个人围成一圈数数,数到3的人退出,求最后剩下的人的编号

public class Main {

	public static void main(String[] args) {
		//50个人,从第一个人开始数,数到3的人出列
		countThree(50, 0, 3);
	}

	/**
	 * 约瑟夫环:已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围。
	 * 从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,
	 * 数到m的那个人又出列;依此规律重复下去,直到圆桌周围的人全部出列。
	 *
	 * @param n	人的总数
	 * @param start	开始报数的序号,start < n
	 * @param m 出列的标记(可以大于n)
	 */
	private static void countThree(int n, int start, int m) {

		List<Integer> list = new ArrayList<Integer>();

		//初始化列表
		for (int i = 1; i <= n; i++) {
			list.add(i);
		}

		while (list.size() > 0) {
			//将前连个移入列表尾端
			for (int j = 0; j < m-1; j++) {
				list.add(list.remove(start));
			}
			//打印出列的序号
			System.out.println(list.remove(start));
		}
	}
}
时间: 2024-11-07 10:45:58

Java实现约瑟夫环:50个人围成一圈数数,数到3的人退出,求最后剩下的人的编号的相关文章

50个人围成一圈数到3和3的倍数时出圈,问剩下的人是谁?在原来的位置是多少?

参考答案: <!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8"> <title></title></head><body> <script> var N = 50; var m = 3; var array = []; for (var i = 0; i < N; i++) { arra

POJ 2886 Who Gets the Most Candies?(线段树模拟约瑟夫环,高合成数)

POJ 2886 Who Gets the Most Candies?(线段树模拟约瑟夫环,高合成数) ACM 题目地址:POJ 2886 Who Gets the Most Candies? 题意: N 个小孩围成一圈,他们被顺时针编号为 1 到 N.每个小孩手中有一个卡片,上面有一个非 0 的数字,游戏从第 K 个小孩开始,他告诉其他小孩他卡片上的数字并离开这个圈,他卡片上的数字 A 表明了下一个离开的小孩,如果 A 是大于 0 的,则下个离开的是左手边第 A 个,如果是小于 0 的, 则是

猴王问题约瑟夫环

[Joseph问题描述]n个人(编号0~(n-1)),从0开始报数,报到(m-1)的退出,剩下的人继续从0开始报数.求胜利者的编号. [求解思路]我们知道第一个人(编号一定是m%n-1) 出列之后,剩下的n-1个人组成了一个新的约瑟夫环(以编号为k=m%n的人开始): k k+1 k+2 ... n-2, n-1, 0, 1, 2, ... k-2 并且从k开始报0. 现在我们把他们的编号做一下转换: k --> 0 k+1 --> 1 k+2 --> 2 ... ... k-2 --&

约瑟夫问题、约瑟夫环

约瑟夫问题(有时也称为约瑟夫斯置换,是一个出现在计算机科学和数学中的问题.在计算机编程的算法中,类似问题又称为约瑟夫环.又称"丢手绢问题".) 1问题来历编辑 据说著名犹太历史学家 Josephus有过以下的故事:在罗马人占领乔塔帕特后,39 个犹太人与Josephus及他的朋友躲到一个洞中,39个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式,41个人排成一个圆圈,由第1个人开始报数,每报数到第3人该人就必须自杀,然后再由下一个重新报数,直到所有人都自杀身亡为止.然而Jos

一个小笔记(3):约瑟夫环

什么是约瑟夫环?其实百度有说http://baike.baidu.com/view/717633.htm 以一个传说中的问题为例子,提供源代码主要是能够通过这个问题,了解如何来操作循环链表 在罗马人占领乔塔帕特后,39 个犹太人与Josephus及他的朋友躲到一个洞中,39个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式,41个人排成一个圆圈,由第1个人开始报数,每报数到第3人该人就必须自杀,然后再由下一个重新报数,直到所有人都自杀身亡为止.然而Josephus 和他的朋友并不想遵从.

uva live 3882 And Then There Was One 约瑟夫环

// uva live 3882 And Then There Was One // // 经典约瑟夫环问题.n是规模,k是每次数的人数,m是第一个出列的人. // // 但是暴力用链表做肯定是不行的,因为 1 <= n <= 10000 , 1<= k <= 10000 // 1 <= m <= n; 虽然我知道公式是什么,但是我并不会推导,看了几乎一个下午的 // 数学推导过程,又弄了几个样例亲自动手实验一下,这样才算是有了一点明悟. // 下面来分享一下自己能力范

C++ 约瑟夫环

约瑟夫环: 已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围.从编号为k的人开始报数,数到m的那个人出列:他的下一个人又从1开始报数,数到m的那个人又出列:依此规律重复下去,直到圆桌周围的人全部出列. 例如:n = 9, k = 1, m = 5 [解答]出局人的顺序为5, 1, 7, 4, 3, 6, 9, 2, 8. 1 int main()//约瑟夫环 2 { 3 int n=9, m=5,k=2;//n是人数(编号1,2,……,x),m是出列号,k是起始人编号 4 int

【数据结构算法】约瑟夫环

1 约瑟夫环: 2 3 指针 4 5 void Joseph(Node*head,int n,int m) 6 { int i,int j; 7 Node*p,*q; 8 q=head;p=q->next; 9 for(j=1) 10 { 11 for(i=1;i<n;i++){ 12 q=p;p=p->next; 13 } 14 printf("%d",p->number); 15 q->next=p->next; 16 p=q->next;

poj 1781 In Danger(约瑟夫环,找规律)

http://poj.org/problem?id=1781 约瑟夫环的模板,每次数到2的人出圈. 但直接求会TLE,n太大. 打表发现答案和n有关系.当n是2的幂的时候,答案都是1,不是2的幂的时候都与小于2的幂那个数相差差值的2的倍数. #include <stdio.h> #include <iostream> #include <map> #include <set> #include <list> #include <stack&