java实现约瑟夫环

import java.util.ArrayList;

/**
 * 
 * 约瑟夫环问题: 已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围。从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数
 * 数到m的那个人又出列;依此规律重复下去,直到剩下最后一个人.
 * 
 */
public class JosephTest {

	public static void main(String[] args) {
		System.out.println(getJoseph(5, 4, 3));			//自定义总人数,出列报数数,开始人编号
	}

	//定义获取方法getJoseph,参数n,m,k分别对应玩游戏的总人数,出列报数数和开始报数的人的编号
	public static Integer getJoseph(int n, int m, int k) {
		ArrayList<Integer> arr = new ArrayList<Integer>(); //定义一个集合arr用于装未出列的人
		for (int i = 1; i <= n; i++) {
			arr.add(i); //先把所有人编号
		}
		int start = k - 1;
		for (int i = start; arr.size() != 1; i++) { 	//由编号为k的人开始,从1开始报数
			if (i == arr.size()) { 						//报数完最后一人后指针跳到第一个人
				i = 0;
				start = -(arr.size() - start); 			//报数每过一轮折算已报数
			}
			if ((i - start + 1) == m) { 				//确定报数为m的人
				arr.remove(i); 							//将其移除集合(出列)
				start = i--; 				//有人退出后,该指针处的人将会成为第一个报数的人
			}
		}
		return arr.get(0);
	}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值