环形链表介绍和约瑟夫环

clipboard

创建一个环形链表:

clipboard

复制代码
public class Josepfu {
    public static void main(String[] args) {
        CircleSingleLinkedList linkedList = new CircleSingleLinkedList();
        linkedList.addBody(5);
        linkedList.showBoys();
    }
}



//创建一个环形的单向链表
class CircleSingleLinkedList{
    //创建一个first节点,当前没有编号
    private  Boy first = null;


    //添加小孩节点,构建一个环形链表
    public void addBody(int k){
        if(k<2){
            System.out.println("请添加两个及两个以上的小孩");
            return;
        }
        Boy curBoy = null;
        for(int i=1;i<=k;i++){
            Boy boy = new Boy(i);
            if(i==1){
                first=boy;
                first.setNext(first);
                curBoy = boy;
            }else{
               curBoy.setNext(boy);
               boy.setNext(first);
               curBoy=boy;
            }
        }
    }

    //遍历环形链表
    public void showBoys(){
        if(first==null){
            System.out.println("链表为空");
        }
        Boy curBoy =first;
        while(true){
            System.out.printf("小孩的编号为%d\n",curBoy.getNo());
            if(curBoy.getNext()==first){
                break;
            }
            curBoy= curBoy.getNext();
        }
    }

}

//创建一个boy类,表示一个节点
class Boy{
    private int no;
    private Boy next;  //指向下一个节点默认为空

    public Boy(int no) {
        this.no = no;
    }

    public int getNo() {
        return no;
    }

    public void setNo(int no) {
        this.no = no;
    }

    public Boy getNext() {
        return next;
    }

    public void setNext(Boy next) {
        this.next = next;
    }
}
复制代码

 

约瑟夫环问题

posted @   青岑  阅读(206)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示
主题色彩