牛客题霸 [ 环形链表的约瑟夫问题] C++题解/答案
生活随笔
收集整理的這篇文章主要介紹了
牛客题霸 [ 环形链表的约瑟夫问题] C++题解/答案
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
牛客題霸 [ 環(huán)形鏈表的約瑟夫問題] C++題解/答案
題目描述
據(jù)說著名猶太歷史學(xué)家 Josephus 有過以下故事:在羅馬人占領(lǐng)喬塔帕特后,39 個猶太人與 Josephus 及他的朋友躲到一個洞中,39 個猶太人決定寧愿死也不要被敵人抓到,于是決定了一種自殺方式,41 個人排成一個圓圈,由第 1 個人開始報數(shù),報數(shù)到 3 的人就自殺,然后再由下一個人重新報 1,報數(shù)到 3 的人再自殺,這樣依次下去,直到剩下最后一個人時,那個人可以自由選擇自己的命運(yùn)。這就是著名的約瑟夫問題。現(xiàn)在請用單向環(huán)形鏈表得出最終存活的人的編號。
n 表示環(huán)形鏈表的長度, m 表示每次報數(shù)到 m 就自殺。
題解:
遍歷環(huán)形鏈表,每遍歷 m 個節(jié)點就刪除一個節(jié)點,知道鏈表只剩下一個節(jié)點就可以了。
代碼:
class Solution { public:/*** * @param n int整型 * @param m int整型 * @return int整型*/int ysf(int n, int m) {// write code hereint a=0;for(int i=2;i<=n;i++){a=(a+m)%i;}return a+1;} };總結(jié)
以上是生活随笔為你收集整理的牛客题霸 [ 环形链表的约瑟夫问题] C++题解/答案的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: qq闪约怎么说话?
- 下一篇: 牛客题霸 [ 集合的所有子集] C++题