带名字的约瑟夫环问题

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
      String name = read.next();
          josephus temp = new josephus();
              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
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值