約瑟夫環(huán)算法

什么是約瑟夫環(huán)呢割岛?
約瑟夫環(huán)(約瑟夫問題)是一個(gè)數(shù)學(xué)的應(yīng)用問題:已知n個(gè)人(以編號(hào)1女器,2,3...n分別表示)圍坐在一張圓桌周圍浸遗。從編號(hào)為k的人開始報(bào)數(shù)猫胁,數(shù)到m的那個(gè)人出列;他的下一個(gè)人又從1開始報(bào)數(shù)跛锌,數(shù)到m的那個(gè)人又出列弃秆;依此規(guī)律重復(fù)下去,直到圓桌周圍的人全部出列髓帽。

image.png

例如:耶穌有13個(gè)門徒菠赚,其中有一個(gè)就是出賣耶穌的叛徒,請(qǐng)用排除法找出這位叛徒:13人圍坐一圈郑藏,從第一個(gè)開始報(bào)號(hào):1衡查,2,3必盖,1拌牲,2,3…歌粥。凡是報(bào)到“3”就退出圈子塌忽,最后留在圈子內(nèi)的人就是出賣耶穌的叛徒。
思路:

  1. 首先假設(shè)失驶,當(dāng)數(shù)字為1的時(shí)候則表示活著的人土居,0為死了,這樣我們就可以用數(shù)組來表示嬉探;
  2. 要考慮的幾個(gè)問題擦耀,要形成一個(gè)環(huán),就是說報(bào)數(shù)到第十三人的時(shí)候甲馋,從頭開始報(bào)數(shù)埂奈;
  3. 報(bào)數(shù)為3的時(shí)候,那個(gè)人退出游戲定躏,這里假設(shè)死了账磺,數(shù)值為0芹敌;
  4. 還有一個(gè)問題,就是當(dāng)報(bào)數(shù)到第四個(gè)人的時(shí)候垮抗,因?yàn)榈谌齻€(gè)人‘死了’氏捞,所以第四個(gè)人要從1開始報(bào)數(shù);
    5.當(dāng)最后只剩下一個(gè)人的時(shí)候冒版,則結(jié)束液茎。
<script>
    var arr = [1,1,1,1,1,1,1,1,1,1,1,1,1];
    var count = 0;
    var num = 0;
    for(var i=0;i<arr.length;i++){
        // 判斷活著
        if(arr[i]==1){
            // 開始計(jì)數(shù)
            count++;
            // 當(dāng)報(bào)數(shù)到第四個(gè)的時(shí)候,從第一個(gè)開始報(bào)數(shù)
            if(count==4){
                count = 1;
            }
            // 當(dāng)報(bào)數(shù)報(bào)到第三個(gè)人的時(shí)候辞嗡,第三個(gè)人就死了
            if(count == 3){
                arr[i]=0;
                num++;
                // 當(dāng)計(jì)數(shù)到最后的時(shí)候捆等,游戲結(jié)束
                if(num == arr.length-1){
                    break;
                }
            }
        }
        // 當(dāng)數(shù)到最后一個(gè)人的時(shí)候,從第一個(gè)人重頭數(shù)续室,如果i=0的時(shí)候栋烤,i++就變成了2,所以i要為0
        if(i==arr.length-1){
            i = -1;
        }
    }
    console.log(arr);
</script>

結(jié)果:

1.png

過了兩年,學(xué)習(xí)了數(shù)據(jù)結(jié)構(gòu)挺狰,用隊(duì)列解決這種問題再簡(jiǎn)單不過明郭,特此補(bǔ)上

// 思路: 定義一個(gè)隊(duì)列,隊(duì)列先進(jìn)先出丰泊,故先進(jìn)來的數(shù)字先出去薯定,再定義個(gè)index用來記錄當(dāng)前元素在隊(duì)列中的位置,位置是3的倍數(shù)瞳购,則刪除
  function isPt(arr) {
    let queue = [];
    let index = 0;
    for (let i = 0; i < arr.length; i++) {
      queue.push(arr[i]);
    }
    while (queue.length !== 1) {
      let item = queue.shift();  // 將環(huán)中數(shù)據(jù)一一刪除
      index += 1;
      if (index % 3 !== 0) { // 不是3的倍數(shù)话侄,再?gòu)沫h(huán)尾加入
        queue.push(item);
      }
    }
    return queue[0];
  }
  // 測(cè)試
  let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13];
  isPt(arr);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市学赛,隨后出現(xiàn)的幾起案子满葛,更是在濱河造成了極大的恐慌,老刑警劉巖罢屈,帶你破解...
    沈念sama閱讀 222,000評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異篇亭,居然都是意外死亡缠捌,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門译蒂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來曼月,“玉大人,你說我怎么就攤上這事柔昼⊙魄郏” “怎么了?”我有些...
    開封第一講書人閱讀 168,561評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵捕透,是天一觀的道長(zhǎng)聪姿。 經(jīng)常有香客問我碴萧,道長(zhǎng),這世上最難降的妖魔是什么末购? 我笑而不...
    開封第一講書人閱讀 59,782評(píng)論 1 298
  • 正文 為了忘掉前任破喻,我火速辦了婚禮,結(jié)果婚禮上盟榴,老公的妹妹穿的比我還像新娘曹质。我一直安慰自己,他們只是感情好擎场,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評(píng)論 6 397
  • 文/花漫 我一把揭開白布羽德。 她就那樣靜靜地躺著,像睡著了一般迅办。 火紅的嫁衣襯著肌膚如雪宅静。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,394評(píng)論 1 310
  • 那天礼饱,我揣著相機(jī)與錄音坏为,去河邊找鬼。 笑死镊绪,一個(gè)胖子當(dāng)著我的面吹牛匀伏,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蝴韭,決...
    沈念sama閱讀 40,952評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼够颠,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了榄鉴?” 一聲冷哼從身側(cè)響起履磨,我...
    開封第一講書人閱讀 39,852評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎庆尘,沒想到半個(gè)月后剃诅,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,409評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡驶忌,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評(píng)論 3 341
  • 正文 我和宋清朗相戀三年矛辕,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片付魔。...
    茶點(diǎn)故事閱讀 40,615評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡聊品,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出几苍,到底是詐尸還是另有隱情翻屈,我是刑警寧澤,帶...
    沈念sama閱讀 36,303評(píng)論 5 350
  • 正文 年R本政府宣布妻坝,位于F島的核電站伸眶,受9級(jí)特大地震影響惊窖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜赚抡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評(píng)論 3 334
  • 文/蒙蒙 一爬坑、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧涂臣,春花似錦盾计、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至岩四,卻和暖如春哭尝,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背剖煌。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工材鹦, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人耕姊。 一個(gè)月前我還...
    沈念sama閱讀 49,041評(píng)論 3 377
  • 正文 我出身青樓桶唐,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親茉兰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子尤泽,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • 百度百科: 約瑟夫環(huán)(約瑟夫問題)是一個(gè)數(shù)學(xué)的應(yīng)用問題:已知n個(gè)人(以編號(hào)1,2规脸,3...n分別表示)圍坐在一張圓...
    KPort閱讀 3,853評(píng)論 0 4
  • 第n個(gè)出列 坯约? ---> 0(**) 從上面可以總結(jié)規(guī)律: 1. f(*) = (f(**)+m)%n n指當(dāng)前未...
    貧僧吃豬蹄閱讀 873評(píng)論 0 0
  • 我是一個(gè)微信編輯闹丐,就是那種編輯整理生活類信息、偶爾轉(zhuǎn)載別人優(yōu)秀文章的微信小編輯被因。每天早上看每條微信的閱讀量是我的習(xí)...
    冰糖陳皮閱讀 2,801評(píng)論 4 9
  • 有個(gè)人問慧海禪師:“禪師妇智,你可有什么與眾不同的地方?” 慧海答:“有” “是什么呢氏身?” 慧海答:“我感覺餓的時(shí)候就...
    流年逝水不在閱讀 152評(píng)論 2 0