环形链表介绍和约瑟夫环
创建一个环形链表:
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; } }
约瑟夫环问题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?