有趣的約瑟夫環問題

大家有沒有聽過約瑟夫環這個問題呢?我們先來看看它是一個什么樣的問題~

約瑟夫環(Josephus)問題是由古羅馬的史學家約瑟夫(Flavius Josephus)提出的。該問題的說法不一,傳說他參加并記錄了公元66—70年猶太人反抗羅馬的起義。約瑟夫作為一個將軍,設法守住了裘達伯特城達47天之久,在城市淪陷之后,他和40名死硬的將士在附近的一個洞穴中避難。在那里,這些叛亂者表決說“要投降毋寧死”。于是,約瑟夫就想出來一個方法。

現在房間內共有n個人,將按下面的規則去殺人:

1、所有的人圍成一圈;

2、順時針報數,每次報到q的人將被殺掉;?

3、 被殺掉的人將從房間內移走;

4、然后從被殺掉的下一個人重新報數,直到剩余一人。

最終聰明的約瑟夫活了下來。

這就是著名的約瑟夫環問題。

下面我們來看一下這個問題是如何拿鏈表實現的呢?


下面我們就用代碼實現一下吧~我們只寫約瑟夫環這一部分,鏈表插刪等操作上節中講過啦!就不重復寫了。

pNode JosephCircle(pNode *pHead,int M)
{assert(pHead);pNode pCur = *pHead;pNode pPcur = *pHead;int count = M;if(*pHead == NULL || M <= 0)              //邊界檢測,M指報數的退出號return NULL;while (pCur->next)                        //找到最后一個節點,使它構成環{pCur = pCur->next;}pCur->next = *pHead;while(pPcur->next != pPcur)               {int count = M;while(--count)                     //報到第M個節點,則刪除{pPcur = pPcur->next;}if(pPcur == *pHead){*pHead = (*pHead)->next;}DeleteListNotTail(pHead,pPcur);}return pPcur;
}

返回值就是最后留下的那個人。出函數之后可以取節點的data知道里邊的內容。這就是簡單的約瑟夫環問題。

點擊繼續鏈表題哦>>微笑微笑



本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/382835.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/382835.shtml
英文地址,請注明出處:http://en.pswp.cn/news/382835.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C語言模擬實現標準庫函數之qsort() 2

C語言模擬實現標準庫函數之qsort() <1> https://blog.csdn.net/csdn_kou/article/details/80158194 排序數字 int int_cmp(const void *elem1, const void *elem2) { return *(int *)elem1 - *(int *)elem2; }int main() { int arr[] { 9,8,7,6,5,4,3,2,1 }; int siz…

node.js windows下安裝與配置

轉自 https://www.cnblogs.com/liuqiyun/p/8133904.html

一系列鏈表題

1、鏈表的倒序輸出&#xff1a;(輸出4&#xff0c;3&#xff0c;2&#xff0c;1)在這里&#xff0c;可以使用遞歸的方式&#xff1a; <span style"font-size:18px;">void Reverse(pNode pHead) {if(pHead){Reverse(pHead->next);cout<<pHead->data…

簡陋版C語言仿真通訊錄之動態內存開辟版本

簡陋版C語言仿真通訊錄 https://blog.csdn.net/csdn_kou/article/details/80287640 簡陋版C語言仿真通訊錄之動態內存開辟版本 給Contact結構體增加一個容量&#xff0c;來表示什么時候增容 #define MAX_NAME 20 typedef struct PeoInfo {char name[MAX_NAME];int age;char …

node.js 代碼修改 自動識別重啟工具

npm install supervisor -g supervisor xx.js 代替 node xx.js 能實現自動重啟服務&#xff0c;識別代碼更新

C語言轉移表之加減乘除無限進化版

主干程序初級版本進階版本版本進化 主干程序 輸入程序解析程序 /*解析字符串 有空格把空格分開 比如輸入&#xff1a;add 1 2 解析后&#xff1a;add12*/ void do_parse(char *buf) {int state 0;int i 0;int argc 0;char *argv[8] {0};for (i 0; buf[i]; i){if (state …

node.js 筆記1 模塊方面

url 模塊 parse 解析url 可以用來獲取查詢參數 xx.js exports.xx xx 另一個文件引用 require(’./xx.js); 獲取的句柄 相當于 xx.js 中的 exports xx.js module.exports xx 這樣被人引用 相當于就是直接拿到了 xx 當require xx 的時候&#xff0c; 如果xx不在當前文件夾 &…

c++之指針引用

指針&#xff1a;指向一塊內存地址的標識。 引用&#xff1a;給已經定義的變量起的別名。 格式&#xff1a; 類型 &引用變量名 已定義的變量名&#xff08;引用變量名和已定義的變量名可以看成是同一個實體&#xff0c;一個改變&#xff0c;另一個也隨之改變&#xff0…

C語言之scanf中的格式

scanf函數原型控制格式1.%[^\n]%*c例子1例子2 1.%[]例子1例子2 scanf函數原型 int scanf( const char *format, ... ); 見可變參數求和 https://blog.csdn.net/csdn_kou/article/details/79996606 控制格式 %c 一個單一的字符 %d 一個十進制整數 %i 一個整數 %e, %f, %…

node.js 將文件目錄讀取 通過匿名函數自執行 將異步改為同步

var fs require(fs);var filesarray []; fs.readdir(html, function(error, files){if(error){console.log(error.stack);console.log(--------);console.log(文件夾讀取失敗);return false;}// 匿名函數自執行&#xff0c; 將異步改為同步(function getFile(i){console.log(…

蛇形數組打印(兩種形式)

#蛇形數組打印 ##第一種形式 形式1 51 2 3 4 516 17 18 19 615 24 25 20 714 23 22 21 813 12 11 10 9 請按任意鍵繼續. . .形式2 513 14 15 16 112 23 24 17 211 22 25 18 310 21 20 19…

node.js 獲取異步方法里面的數據 =》 兩種方式

第一種&#xff1a; 通過回調函數實現&#xff1a; var fs require(fs); function getmime(callback){ fs.readFile(./t1.js, function(err, data){// 現在理解&#xff0c;異步方法里還有別的引用 就不會提前釋放callback(data);}); }getmime(function(data){console.log(…

python入門--基本語法

標準數據類型&#xff1a;Number(數字)&#xff0c;String(字符串)&#xff0c;List(列表)&#xff0c;Tuple(元組)&#xff0c;Sets(集合)&#xff0c;Dictionary(字典)Number只支持int(表示長整型)&#xff0c;float&#xff0c;bool&#xff0c;complex&#xff08;復數&…

Linux網站大雜燴《自己查閱》

從網絡上拷貝別人歸納的列表。 Linux優秀網站列表 國內 http://www.chinaunix.net/ 國內最火爆的unix/linux論壇 http://www.linuxforum.net/ linux愛好者交流的場所&#xff0c;側重編程開發 http://www.linuxaid.com.cn/ 面向初學者者提供資料 http://www.ibm.com/de…

python之條件、循環語句

其實&#xff0c;很多語言的語法都是相通的&#xff0c;包括初學python一樣。 今天要說的是條件、循環語句。這部分也是相對比較簡單的&#xff0c;就python而言&#xff0c;只是書寫方式稍作改動罷了。 1、條件語句 &#xff08;1&#xff09;格式&#xff1a; if 判斷條件…

node.js Promise簡單介紹

轉自百度&#xff1a; https://baijiahao.baidu.com/s?id1589455136001194151&wfrspider&forpc

數據結構之空間復雜度和空間復雜度

1.空間復雜度計算方法 2.時間復雜度計算方法非遞歸遞歸情況遞歸總次數*每次遞歸次數 1.空間復雜度 空間復雜度是指 執行這個算法所需要的內存空間。空間復雜度是函數中創建對象的個數關于問題規模函數表達式&#xff0c;一般情況下用O漸進表示法表示 計算方法 1.忽略常數&…

node.js 獲取異步方法里面數據 的方式

第一種 使用回調函數&#xff1a; function getData(callback){setTimeout(function(){var name xxxx;callback(name);}, 1000); }// 外部獲取異步方法里面的數據 采用回調函數的方式 getData(function(data){console.log(name); });第二種方式 事件觸發&#xff1a; var fs…

C語言malloc和calloc的區別

是否對申請的區域進行初始化而已 但是我想你也知道我們寫程序的時候多用malloc而很少用calloc&#xff0c;何解&#xff1f; 因為calloc雖然對內存進行了初始化&#xff08;全部初始化為0&#xff09;&#xff0c;但是同樣也要降低效率的 calloc相當于 p malloc(); memse…

node.js將buffer對象轉換為json對象

d 是buffer對象 let jsstr JSON.stringify(d);let jsondata JSON.parse(jsstr);let buf new Buffer(jsondata);let data buf.toString();sx JSON.parse(data);console.log(sx[peer_count]);詳見百度經驗: https://jingyan.baidu.com/article/8ebacdf079f00549f75cd564.htm…