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