java数据结构-约瑟夫环

这个专题记录自己学习数据结构的过程,也希望能给自学的小伙伴一点帮助。

class Josephu{
    private Boy first =null;
    //增加
    public void addBoy(int num){
        if(num<1){
            System.out.println("输入数据错误");

        }
        Boy temp=null;
        for(int i =1;i<=num;i++){
            Boy boy=new Boy(i);
            if(i==1){
                first=boy;
                temp=first;
                boy.setNext(first);
            }else {
                temp.setNext(boy);
                temp=temp.getNext();
                boy.setNext(first);
            }

        }
    }

    //遍历
    public void list(){
        if(first==null){
            System.out.println("环内无数据");
            return;
        }
        Boy temp=first;
        if(first.getNext()==first){
            System.out.println(temp.toString());
            return;
        }
        while (temp.getNext()!=first){
            System.out.println(temp.toString());
            temp=temp.getNext();
        }
        System.out.println(temp.toString());
    }
    //计数
    public int sort(){
        if(first==null){

            return 0;
        }
        Boy temp=first;
        if(first.getNext()==first){
            System.out.println(temp.toString());
            return 1;
        }
        int i =0;
        while (temp.getNext()!=first){
            i++;
            temp=temp.getNext();
        }
        i++;
        return i;
    }
    //环问题
    public void countBoy(int start,int num){
        int i=this.sort();
        if(start<0||start>i){
            System.out.println("输入数据有错误");
            return;
        }
        if(first.getNext()==first){
            System.out.println(first.toString());
        }
        Boy helper=first;
        while (helper.getNext()!=first){
            helper=helper.getNext();
        }
        for(int j=1;j<start;j++){
            first=first.getNext();
        }
        while(true){
            if(first==helper){
                break;
            }
            for(int j=0;j<num-1;j++){
                first=first.getNext();
                helper=helper.getNext();
            }
            System.out.println(first.toString());
            helper.setNext(first.getNext());
            first=first.getNext();
        }
        System.out.println(first);
    }
}
class Boy {
    private int id ;
    private Boy next;

    @Override
    public String toString() {
        return "Boy{" +
                "id=" + id +
                '}';
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public Boy getNext() {
        return next;
    }

    

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值