带名字的约瑟夫环问题

来源:互联网 发布:怎么在mac上设置邮箱 编辑:程序博客网 时间:2024/05/01 09:52

1)带人名的Josephus问题

Josephus问题为:设编号为12… nn个人围坐一圈,约定编号为k1<=k<=n)的人开始从1报数,数到的那个人出列要求:它的下一位又重新1开始报数,数到m的那个人又出列,依次类推,直到所有人出列为止。

 

输入人的个数nn<=64),接下来每行输入一个人的名字(人名不超过15个字符),接下来输入kmkm之间用逗号隔开。

最后按照人名输出出列的顺序,每行输出一个人名。

如下表给出的样例。

 

样例输入

样例输出

5

Caobainan

Mazhongyi

Shenyongqiang

Shenyongqiang

Mazhongyi

Taozhengyi

Taozhengyi

Caobainan

Jiangdebing

Jiangdebing

 

2,3

 

java的快感就在于快啊。。。
package 期末算法设计;

import java.util.LinkedList;
import java.util.Scanner;

public class Josephus {
class josephus{
String name ;
}
LinkedList j = new LinkedList<>();
public void getJosephus(){
Scanner read = new Scanner(System.in);
int n = read.nextInt();
for(int i=0;i
     Stringname = read.next();
        josephus temp = newjosephus();
            temp.name=name;
              j.add(temp);
           }
    }
public void removeJosephus(){
Scanner read = new Scanner(System.in);
int k=read.nextInt();
int m=read.nextInt()-1;
int r=1;
int i=k;
while(!j.isEmpty()){
i=i%j.size();
if(r%m==0){
System.out.println(j.get(i).name);
j.remove(i);
}
i++;
r++;
}
}
public static void main(String[] args){
Josephus J = new Josephus();
J.getJosephus();
J.removeJosephus();
}
}


0 0