约瑟夫java算法代码

/**
 *
 */
package com.tjb.test;

/**
 * @author tjbworkshop
 *
 */
import   java.util.*;  

public   class  Josephus{  
 
 private List beginList = null;
 private int total = 0;
 private int pass = 0;
 private int rest = 1;
 
 
 public List getBeginList() {
  return beginList;
 }

 public void setBeginList(List beginList) {
  this.beginList = beginList;
 }

 public int getPass() {
  return pass;
 }

 public void setPass(int pass) {
  this.pass = pass;
 }

 public int getTotal() {
  return total;
 }
 
 public int getRest() {
  return rest;
 }

 public void setRest(int rest) {
  this.rest = rest;
 }

 public void setTotal(int total) {
  this.total = total;
 }

 @SuppressWarnings("unchecked")
 public Josephus(int total,int pass)
 {
  this.total = total;
  this.pass = pass;
  this.beginList = new LinkedList();
  for(int i = 1;i<=total;i++)
  {
   beginList.add(new Integer(i));
  }
 }
 
 public List jos()
 {
  Iterator it = getBeginList().iterator();
  while(total--!=getRest())
  {
   for(int i = 1;i<=getPass();i++)
   {
    if(!it.hasNext())
     it = beginList.iterator();
    System.out.println("游标指向:"+it.next());/*it.next()必须执行*/
   }
   it.remove();
  }
  return getBeginList();
 }
 
 public   static   void   main(String[]   args){  
 
  Josephus jos = new Josephus(4,2);
  jos.setRest(1);
  System.out.println(jos.jos().get(0));
 }  
}  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值