日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > java >内容正文

java

【Java】单循环链表解决约瑟夫环问题

發(fā)布時(shí)間:2025/3/15 java 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Java】单循环链表解决约瑟夫环问题 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

問題描述

據(jù)說著名猶太歷史學(xué)家 Josephus有過以下的故事:在羅馬人占領(lǐng)喬塔帕特后,39 個(gè)猶太人與Josephus及他的朋友躲到一個(gè)洞中,39個(gè)猶太人決定寧愿死也不要被敵人抓到,于是決定了一個(gè)自殺方式,41個(gè)人排成一個(gè)圓圈,由第1個(gè)人開始報(bào)數(shù),每報(bào)數(shù)到第3人該人就必須自殺,然后再由下一個(gè)重新報(bào)數(shù),直到所有人都自殺身亡為止。然而Josephus 和他的朋友并不想遵從。首先從一個(gè)人開始,越過k-2個(gè)人(因?yàn)榈谝粋€(gè)人已經(jīng)被越過),并殺掉第k個(gè)人。接著,再越過k-1個(gè)人,并殺掉第k個(gè)人。這個(gè)過程沿著圓圈一直進(jìn)行,直到最終只剩下一個(gè)人留下,這個(gè)人就可以繼續(xù)活著。問題是,給定了和,一開始要站在什么地方才能避免被處決?Josephus要他的朋友先假裝遵從,他將朋友與自己安排在第16個(gè)與第31個(gè)位置,于是逃過了這場死亡游戲。

數(shù)據(jù)結(jié)構(gòu)

輔助解決問題的數(shù)據(jù)結(jié)構(gòu):
單向循環(huán)鏈表

編寫結(jié)點(diǎn)類

本例中用Integer而放棄了泛型

public class LinkedNode {private Integer data;private LinkedNode next;public LinkedNode() {this.data = null;this.next = null;}public LinkedNode(Integer element) {this.data = element;this.next = null;}public Integer getData() {return data;}public void setData(Integer data) {this.data = data;}public LinkedNode getNext() {return next;}public void setNext(LinkedNode next) {this.next = next;}}

約瑟夫環(huán)的鏈表實(shí)現(xiàn)(單向循環(huán)鏈表)

public class CircularSinglyLinkedList {/*** 尾引用*/protected LinkedNode rear;/*** 頭引用*/protected LinkedNode first;public CircularSinglyLinkedList() {rear = null;}public void joseph(int n, int m) {//createCircular函數(shù)初始化n個(gè)結(jié)點(diǎn)的約瑟夫環(huán)createCircular(n);//初始化pre為表尾LinkedNode pre = rear;//初始化p為表頭LinkedNode p = rear.getNext();//初始化計(jì)數(shù)器countint count = 1;System.out.println("出環(huán)的順序?yàn)?#xff1a;");//循環(huán)到環(huán)中只剩一個(gè)結(jié)點(diǎn)while (p.getNext() != p) {//計(jì)數(shù)器未累加到密碼值if (count < m) {pre = p;p = p.getNext();count++;} else { //累加器加到密碼值System.out.print(p.getData() + " ");//刪除p結(jié)點(diǎn)pre.setNext(p.getNext());//p賦為pre當(dāng)前后繼p = pre.getNext();//count賦值1,重新計(jì)數(shù)count = 1;}}//輸出最后一個(gè)結(jié)點(diǎn)編號System.out.print(p.getData() + " ");}/*** 根據(jù)參數(shù)n生成循環(huán)單鏈表* @param n*/protected void createCircular(int n) {//生成第一個(gè)結(jié)點(diǎn),賦給尾引用rear = new LinkedNode(1);first = rear;//依次尾插入2、3、...、n新結(jié)點(diǎn)for (int i = 2; i <= n; i++) {LinkedNode node = new LinkedNode(i);rear.setNext(node);rear = node;}//尾結(jié)點(diǎn)引用賦值為頭結(jié)點(diǎn),形成循環(huán)鏈表rear.setNext(first);}}

測試

public class JosephTester {public static void main(String[] args) {CircularSinglyLinkedList list = new CircularSinglyLinkedList();list.joseph(5, 3);}}

測試結(jié)果

出環(huán)的順序?yàn)?#xff1a; 3 1 5 2 4

總結(jié)

以上是生活随笔為你收集整理的【Java】单循环链表解决约瑟夫环问题的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。