Java簡(jiǎn)單實(shí)現(xiàn)約瑟夫環(huán)算法示例
本文實(shí)例講述了Java簡(jiǎn)單實(shí)現(xiàn)約瑟夫環(huán)算法。分享給大家供大家參考,具體如下:
1.算法背景:
羅馬人攻占了喬塔帕特,41人藏在一個(gè)山洞中躲過(guò)了這場(chǎng)浩劫。這41個(gè)人中,包括歷史學(xué)家josephus和他的一個(gè)朋友。剩余的39個(gè)人為了表示不向羅馬人屈服,決定集體自殺。大家決定了一個(gè)自殺方案,所有這41人圍城一個(gè)圓圈,由第一個(gè)人開(kāi)始順時(shí)針報(bào)數(shù),沒(méi)報(bào)數(shù)為3的人就立刻自殺,然后由下一個(gè)人重新開(kāi)始報(bào)數(shù)
仍然是每報(bào)數(shù)為3的人就立刻自殺,......,知道所有人都自殺死亡為止.
約瑟夫和他的朋友并不想自殺,于是約瑟夫想到了一個(gè)計(jì)策,他們兩個(gè)同樣參數(shù)到自殺方案中,但是最后卻躲過(guò)了自殺。請(qǐng)問(wèn)是怎么做到的
2.下面直接代碼進(jìn)行實(shí)現(xiàn):
public class YueSeFuHuan { static final int nums = 41;// 總共多少人 static final int killMan = 3;// 數(shù)到3則被殺 public static void main(String[] args) { jufehus(2); } public static void jufehus(int alive) { int[] man = new int[nums];// 未被殺的都被標(biāo)記為0 int pos = -1;// 數(shù)組角標(biāo) int i = 0; int count = 1;// 殺到第幾個(gè)記錄值 while (count <= nums) { do { pos = (pos + 1) % nums;// 循環(huán)標(biāo)記 if (man[pos] == 0) i++; if (i == killMan) { i = 0; // 重置 break;// 找到了被殺的位置,跳出循環(huán),進(jìn)行標(biāo)記 } } while (true); man[pos] = count; count++; } System.out.println("腳本之家測(cè)試結(jié)果:"); // 顯示不被殺的位置 alive = count - alive; for (int j = 0; j < man.length; j++) { if (man[j] >= alive) System.out.println("不被殺的位置是->" + (j + 1)); } } }
打印出結(jié)果是:
更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。
- java基于雙向環(huán)形鏈表解決丟手帕問(wèn)題的方法示例
- Java用單向環(huán)形鏈表來(lái)解決約瑟夫環(huán)Josepfu問(wèn)題
- Java數(shù)據(jù)結(jié)構(gòu)與算法之雙向鏈表、環(huán)形鏈表及約瑟夫問(wèn)題深入理解
- Java 數(shù)據(jù)結(jié)構(gòu)與算法系列精講之環(huán)形鏈表
- java 實(shí)現(xiàn)約瑟夫環(huán)的實(shí)例代碼
- Java解決約瑟夫問(wèn)題代碼實(shí)例
- java使用鏈表實(shí)現(xiàn)約瑟夫環(huán)
- Java數(shù)據(jù)結(jié)構(gòu)之環(huán)形鏈表和約瑟夫問(wèn)題詳解
相關(guān)文章
springcloud檢索中間件?ElasticSearch?分布式場(chǎng)景的使用
單機(jī)的elasticsearch做數(shù)據(jù)存儲(chǔ),必然面臨兩個(gè)問(wèn)題:海量數(shù)據(jù)存儲(chǔ)問(wèn)題、單點(diǎn)故障問(wèn)題,本文重點(diǎn)給大家介紹springcloud檢索中間件?ElasticSearch?分布式場(chǎng)景的運(yùn)用,感興趣的朋友跟隨小編一起看看吧2023-10-10mybatis動(dòng)態(tài)SQL?if的test寫(xiě)法及規(guī)則詳解
這篇文章主要介紹了mybatis動(dòng)態(tài)SQL?if的test寫(xiě)法及規(guī)則詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01Spring security BCryptPasswordEncoder密碼驗(yàn)證原理詳解
這篇文章主要介紹了Spring security BCryptPasswordEncoder密碼驗(yàn)證原理詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03spring boot 錯(cuò)誤頁(yè)面配置解決方案
這篇文章主要介紹了spring boot 錯(cuò)誤頁(yè)面配置解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10redis實(shí)現(xiàn)多進(jìn)程數(shù)據(jù)同步工具代碼分享
這篇文章主要介紹了使用redis實(shí)現(xiàn)多進(jìn)程數(shù)據(jù)同步工具的代碼,大家參考使用吧2014-01-01Spring Cloud Feign 自定義配置(重試、攔截與錯(cuò)誤碼處理) 代碼實(shí)踐
這篇文章主要介紹了Spring Cloud Feign 自定義配置(重試、攔截與錯(cuò)誤碼處理) 實(shí)踐,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08