


版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、Josephus 約瑟夫 問題n 個競賽者排成一個環(huán)形,依次挨次編號1,2,n。從某個指定的第1 號開頭,沿環(huán)計數(shù),每數(shù)到第 m 個人就讓其出列,且從下一個人開頭重計數(shù),連續(xù)進(jìn)展下去。這個過程始終進(jìn)展到全部的人都出列為止。最終出列者為優(yōu)勝者。無論是用鏈表實現(xiàn)還是用數(shù)組實現(xiàn)來解約瑟夫問題都有一個共同點:要模擬整個玩耍過程, 不僅程序?qū)懫饋肀容^麻煩,而且時間簡單度高達(dá)O(nm),當(dāng)n,m 格外大(例如上百萬,上千萬)的時候,幾乎是沒有方法在短時間內(nèi)出結(jié)果的。留意到原問題僅僅是要求出最終的成功 者。為了爭辯便利,先把問題略微轉(zhuǎn)變一下,并不影響原意:問題描述:n 個人0(n-1)0 開頭報數(shù),報到(m
2、-1)0 開頭報數(shù)。求成功者的編號。我們知道第一個人(編號肯定是 m%n-1) 出列之后,剩下的 n-1 個人組成了一個的約瑟夫環(huán)k=m%n的人開頭: k k+1 k+2 . n-2, n-1, 0, 1, 2, . k-2并且從k 開頭0?,F(xiàn)在我們把他們的編號做一下轉(zhuǎn)換:k- 0k+1- 1k+2- 2.k-2- n-2變換后就完完全全成為了(n-1)個人報數(shù)的子問題,假設(shè)我們知道這個子問題的解:例如 xx 變回去不剛好就是n 個人狀況的解嗎?變回去的公式很簡潔:x”=(x+k)%n如何知道(n-1)個人報數(shù)的問題的解?明顯,只要知道(n-2)個人的解就行了。(n-2)個人的解呢?固然是先求
3、(n-3)的狀況這明顯就是一個倒推問題!遞推公式:fii 個人玩玩耍報m 退出最終成功者的編號,最終的結(jié)果自然是fn遞推公式f1=0;fi=(fi-1+m)%i;(i1)1-n 挨次算出 fi的數(shù)值,最終結(jié)果是 fn。由于實際生1 開頭,我們輸出fn+1 由于是逐級遞推,不需要保存每個fi,程序也是很簡潔:#include mainint n, m, i, s=0;printf (“N M = “);scanf(“%d%d“, &n, &m);for (i=2; i=n; i+) s=(s+m)%i; printf (“The winner is %dn“, s+1);這個算法的時間簡單度為O
4、(n)n,m 等于一百萬, 往會成倍地提高算法執(zhí)行效率。PKUJoseph 相關(guān)問題:1012Joseph一半好人一半壞人。模擬打表。#include using namespace std;int a14;bool fun(int k,int m)/s 表示第I(1,2,.,k)次刪除數(shù)組中的數(shù)的下標(biāo),留意:隨著刪除,數(shù)組的大小在漸漸減小。int s=0,t=2*k; for(int i=1;i=k;+i)s=(s-1+m)%t;-t;if(sk)return false;return true;int mainint i,j; for(i=1;ik & k)coutakendl; retu
5、rn 0;2359Questions標(biāo)準(zhǔn)約瑟夫問題+字符串#include using namespace std;char s30002;int mainchar ch;int len=0; while(ch=getchar)!=EOF)if(ch!=”n”)+len; slen=ch;int t=0;for(int i=2;i=len;+i)t=(t+2022)%i;if(st+1=” ”)cout“No“endl; else if(st+1=”?”)cout“Yes“endl; elsecout“No comments“endl;return 0;1781In Danger只考慮M 2
6、1.3。#include #include using namespace std;int mainstring s; while(cins)if(s=“00e0“)break;string str=s.substr(0,2);int i,j;int t=s3-”0”; for(i=0;it;+i)str+=”0”;int len=str.length; int sum=str0-”0”;for(i=1;ilen;+i) sum=sum*10+(stri-”0”); int a100;j=0;while(sum)aj=sum%2;+j;sum/=2;for(i=0;ij/2;+i)t=ai;
7、ai=aj-1-i;aj-1-i=t;t=a0;for(i=1;ij;+i)ai-1=ai;aj-1=t;t=a0;for(i=1;ij;+i)t=t*2+ai; couttendl;return 0;2244Eeny Meeny MooN 個城市輪番斷電,求最小的M 21 開頭斷,相當(dāng)于循環(huán)N-1 次。#include using namespace std;int fun(int m,int n)int s=0,i; for(i=2;im & m)j=2;while(fun(m,j)!=1)+j;coutjendl;return 0;3517And Then There Was One22
8、44 一樣,結(jié)果加上初始值就可以。#includeusing namespace std;int mainint i,j,k,m,n,s;while(1)cinnkm;if(n=0 & k=0 & m=0)break;s=0;for(i=2;i=n-1;i+)/N-1 次循環(huán)s=(s+k)%i;cout(s+m)%n+1endl;/結(jié)果加初始值return 0;2939Flavius Josephus Reloaded#include #include using namespace std;typedef long long ll;#define HASHLEN 1987039struct
9、hashtypeint v;/value,查找的值int cnt; /count,查找的次數(shù)hashHASHLEN;int addorfind(int v,int cnt)int t=v%HASHLEN; while(hasht.v!=-1 & hasht.v!=v)t+; if(t=HASHLEN)t=0;if(hasht.v!=-1) return t;t=cnt;hasht.v=v; return -1;int mainint n,a,b; while(scanf(“%d“,&n) & n)scanf(“%d%d“,&a,&b); memset(hash,-1,sizeof(hash);
10、 ll x=0;int cnt=1; addorfind(0,0);while(1)x=x*x%n;x=(x*a+b)%n;/在HASH 中第t 個位置查找到x int t=addorfind(int)x,cnt);/t,cnt:t 個數(shù)和第cnt 個數(shù)相等if(t!=-1)printf(“%dn“,n-cnt+t);break;+cnt;return 0;PKU 2800#include #include using namespace std;int mainlong long N,K;while(cinNK)long long sk,ssk,i,s,e,tmp,ans;sk = sqrt(double)K);ssk = K / sk;for (i = 1, ans = 0; i = N & i K)ans += (N - K) * K;for (i = sk; i 1; i-)s
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 心理營銷活動方案
- 張家界旅游抽獎活動方案
- 徒步登山活動方案
- 開業(yè)活動舞隊活動方案
- 微笑城市活動方案
- 開學(xué)吉祥活動方案
- 異地戀見面心理活動方案
- 開展春雷活動方案
- 基礎(chǔ)設(shè)施建設(shè)財務(wù)管理制度及流程
- 心靈傾訴活動方案
- 加油站客戶服務(wù)與管理手冊
- 廣東省申請設(shè)立出版物零售單位登記表-空白表
- 欣賞《嘎達(dá)梅林》-課件
- GB/T 4074.8-2009繞組線試驗方法第8部分:測定漆包繞組線溫度指數(shù)的試驗方法快速法
- GB/T 28575-2020YE3系列(IP55)三相異步電動機(jī)技術(shù)條件(機(jī)座號63~355)
- 國際公法學(xué) 馬工程課件 4 第四章
- 青海省西寧市《職業(yè)能力測試》事業(yè)單位國考真題
- 溝通中的提問技巧課件
- 2023年浙江黃龍體育發(fā)展有限公司招聘筆試模擬試題及答案解析
- 外科學(xué)骨折概論課件
- 阿片類藥物鎮(zhèn)痛機(jī)制課件
評論
0/150
提交評論