約瑟夫經(jīng)典問(wèn)題擴(kuò)展成雙向約瑟夫問(wèn)題
約瑟夫問(wèn)題是一個(gè)經(jīng)典的問(wèn)題,我們不妨將這個(gè)經(jīng)典問(wèn)題進(jìn)行擴(kuò)展,變成一個(gè)雙向的約瑟夫問(wèn)題。
已知 n 個(gè)人(不妨分別以編號(hào) 1,2,3,...,n 代表 )圍坐在一張圓桌周圍,首先從編號(hào)為 k 的人從 1 開始順時(shí)針報(bào)數(shù),1, 2, 3, ...,記下順時(shí)針數(shù)到 m 的那個(gè)人,同時(shí)從編號(hào)為 k 的人開始逆時(shí)針報(bào)數(shù),1, 2, 3, ...,數(shù)到 m 后,兩個(gè)人同時(shí)出列。然后從出列的下一個(gè)人又從 1 開始繼續(xù)進(jìn)行雙向報(bào)數(shù),數(shù)到 m 的那兩個(gè)人同時(shí)出列,...;。依此重復(fù)下去,直到圓桌周圍的人全部出列。直到圓桌周圍只剩一個(gè)人為止。
如果雙向報(bào)數(shù)報(bào)到 m 時(shí)落在同一個(gè)人身上,那本次出列的只有一個(gè)人。
例如:5,1,2。則總共5個(gè)人,從1開始順時(shí)針報(bào)數(shù),數(shù)到2,定位編號(hào)2;同時(shí)從1開始報(bào)數(shù)數(shù)到2,定位編號(hào)5;2和5同時(shí)出列。然后繼續(xù)開始報(bào)數(shù),順時(shí)針報(bào)數(shù)3,4,定位到4;逆時(shí)針報(bào)數(shù)4,3,定位3;4和3同時(shí)出列。最后剩余的為編號(hào)1。輸出為:2-5,4-3,1,。
如果輸入:6,2,3。則輸出:4-6,2,1-3,5,。其中第2次只輸出一個(gè)2,表示第二次雙向報(bào)數(shù)時(shí),恰好都落在編號(hào)2上,所以只有一個(gè)編號(hào)出列。
輸入:
n,k,m
輸出:
按照出列的順序依次輸出編號(hào)。同時(shí)出列編號(hào)中間用減號(hào)"-”連接。
非法輸入的對(duì)應(yīng)輸出如下
a)
- 輸入:n、k、m任一個(gè)為0
- 輸出:n,m,k must bigger than 0.
b)
- 輸入:k>n
- 輸出:k should not bigger than n.
測(cè)試輸入
1,0,0
1,2,1
5,1,2
測(cè)試輸出
n,m,k must bigger than 0.
k should not bigger than n.
2-5,4-3,1,
源代碼
#include<stdio.h> #include<malloc.h> #include<stdlib.h> typedef int ElemType; int n,m,k; //定義一個(gè)全局變量 typedef struct DuLNode //雙向循環(huán)鏈表結(jié)構(gòu) { ElemType data; struct DuLNode *prior; struct DuLNode *next; }DuLNode,*DuLinkList; void Create(DuLinkList &H) //創(chuàng)建帶頭結(jié)點(diǎn)的雙向循環(huán)鏈表 { DuLinkList p,q; int i; H=(DuLinkList)malloc(sizeof(DuLNode)); p=H; q=H; for(i=1;i<=n;i++) { p=(DuLinkList)malloc(sizeof(DuLNode)); p->data=i; p->prior=q; q->next=p; q=p; } p->next=H; H->prior=p; } void Delete(DuLinkList &P) //刪除結(jié)點(diǎn) { P->prior->next=P->next; P->next->prior=P->prior; } int main() { int i; DuLinkList H,l,R,right,left; //分別用以表示頭結(jié)點(diǎn),l和R都用于找k的值,向右(順時(shí)針),向左(逆時(shí)針) scanf("%d,%d,%d",&n,&k,&m); if(!n||!k||!m) { printf("n,m,k must bigger than 0.\n"); return 0; } if(k>n) { printf("k should not bigger than n.\n"); return 0; } Create(H); R=H->next ; while(R->data!=k) { R=R->next; } l=R; while(n) { right=R; left=l; for(i=1;i<m;i++) { right=right->next; left=left->prior; //遇見(jiàn)頭結(jié)點(diǎn)需要特殊處理 if(right==H) right=right->next; if(left==H) left=left->prior; } R=right->next; l=left->prior; if(R==H) R=R->next; if(l==H) l=l->prior; if(right!=left) { n=n-2; printf("%d-%d,",right->data,left->data); Delete(right); Delete(left); } else { n=n-1; printf("%d,",right->data); Delete(right); } } printf("\n"); }
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)我們的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
上一篇:C語(yǔ)言和C++的6點(diǎn)區(qū)別
欄 目:C語(yǔ)言
本文標(biāo)題:約瑟夫經(jīng)典問(wèn)題擴(kuò)展成雙向約瑟夫問(wèn)題
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/422.html
您可能感興趣的文章
- 01-10深入理解約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)- 解析最少換車次數(shù)的問(wèn)題詳解
- 01-10c語(yǔ)言 跳臺(tái)階問(wèn)題的解決方法
- 01-10HDOJ 1443 約瑟夫環(huán)的最新應(yīng)用分析詳解
- 01-10用貪心法求解背包問(wèn)題的解決方法
- 01-10深入第K大數(shù)問(wèn)題以及算法概要的詳解
- 01-10深入N皇后問(wèn)題的兩個(gè)最高效算法的詳解
- 01-10深入解析Linux下\r\n的問(wèn)題
- 01-10數(shù)組中求第K大數(shù)的實(shí)現(xiàn)方法
- 01-10深入理解大數(shù)與高精度數(shù)的處理問(wèn)題


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
- 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
- 04-02c語(yǔ)言用函數(shù)寫分段 用c語(yǔ)言表示分段
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
- 04-02c語(yǔ)言編寫函數(shù)冒泡排序 c語(yǔ)言冒泡排
- 04-02c語(yǔ)言沒(méi)有round函數(shù) round c語(yǔ)言
- 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
- 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10delphi制作wav文件的方法
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?