约瑟夫环(排成圈)

简介: /** * 约瑟夫环问题主要是考虑下标问题,只要解决了下标控制问题,这个题目就不难了 * 在这里我是分成了3中情况: * 1,下标小于剩余人数时:删除当前元素,并将下标后移 * 2.下标大于剩余人数时:用下标对剩余人数取于,删除元素,并下移下标 * 3.

/**
* 约瑟夫环问题主要是考虑下标问题,只要解决了下标控制问题,这个题目就不难了
* 在这里我是分成了3中情况:
* 1,下标小于剩余人数时:删除当前元素,并将下标后移
* 2.下标大于剩余人数时:用下标对剩余人数取于,删除元素,并下移下标
* 3.下标等于剩余人数或者是剩余人数的倍数的时候:移除最后一个元素,并让下标后移
*/

 

 1 import java.util.LinkedList;
 2 import java.util.Scanner;
 3 
 4 public class StudentCode {
 5 
 6     public static void main(String[] args) {
 7         LinkedList<Integer> al=new LinkedList<Integer>();
 8         Scanner sc=new Scanner(System.in);
 9         int m=sc.nextInt();
10         int n=sc.nextInt();
11         //初始化队列,给每个元素赋值
12         for(int i=0;i<m;i++){
13             al.add(i+1);
14         }
15         int index=n;
16         int t=0;
17         while(al.size()!=1){
18             //第一种情况
19             if(index<al.size()){
20                 //下标和逻辑值相差1(逻辑下标从1开始,实际下标从0开始)
21                 al.remove(index-1);
22                 //逻辑下标后移
23                 index=index+n-1;
24             }else if((index)%al.size()!=0){
25                 //第二种情况
26                 t=(index)%al.size();
27                 index=t+n-1;
28                 al.remove(t-1);
29             }else if((index)%al.size()==0||index%al.size()==0){
30                 //第三种情况
31                 al.removeLast();
32                 index=1+n-1;
33             }
34         }
35         //输出元素
36         System.out.println(al.get(0));
37     }
38 }

 

相关文章
|
3月前
每日一题——圆圈中最后剩下的数字(约瑟夫环问题)
每日一题——圆圈中最后剩下的数字(约瑟夫环问题)
|
5月前
约瑟夫环问题的几种解法
约瑟夫环问题的几种解法
74 0
|
6月前
|
算法
约瑟夫环问题(三种方法)
约瑟夫环问题(三种方法)
94 0
蓝桥 发现环 (拓扑排序判环)
蓝桥 发现环 (拓扑排序判环)
|
9月前
|
算法
食物链问题(并查集)
食物链问题(并查集)
66 0
|
10月前
|
算法 索引 Python
细究“约瑟夫环”
细究“约瑟夫环”
73 0
|
11月前
约瑟夫环问题
使用queue<int>q记得加上头文件#include<queue>
55 0
LeetCode每日一题——1823.找出游戏的获胜者(约瑟夫环问题)
共有 n 名小伙伴一起做游戏。小伙伴们围成一圈,按 顺时针顺序 从 1 到 n 编号。确切地说,从第 i 名小伙伴顺时针移动一位会到达第 (i+1) 名小伙伴的位置,其中 1 <= i < n ,从第 n 名小伙伴顺时针移动一位会回到第 1 名小伙伴的位置。
107 0
LeetCode每日一题——1823.找出游戏的获胜者(约瑟夫环问题)
约瑟夫环
题目: 已知n个人(以编号1,2,3--n分别表示)围坐在一张圆桌周围。从编号为1的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人有出列;以此规律重复下去,知道圆桌周围的人全部出列。输出出列顺序和最后剩下的人。
74 0