約瑟夫環問題

2021-07-24 05:13:10 字數 411 閱讀 8291

約瑟夫環問題:使用有80個小朋友手拉手圍成一圈,由第乙個小朋友開始從1開始數,數到3的小朋友退出,再從後面的小朋友從1數起,數到3的再退出,以此遊戲下去,問最後剩下哪個小朋友? **如下:

public void findchild()

//設定計數器,進行數數

int count = 0;

//記錄退出小朋友人數

int number = 0;

//記錄陣列下標

int i = 0;

//當退出人數小於(總人數-1)時遍歷小朋友陣列,數到3的小朋友退出

while(number}

}i=0;//重新遍歷陣列

} //遍歷陣列,找出編號不為0的小孩

for (int j=0;j} }

約瑟夫問題 約瑟夫環

約瑟夫 問題 有時也稱為約瑟夫斯置換,是乙個出現在電腦科學和數學中的問題。在計算機程式設計的演算法中,類似問題又稱為約瑟夫環。又稱 丟手絹問題 據說著名猶太歷史學家 josephus有過以下的故事 在羅馬人占領喬塔帕特後,39 個猶太人與josephus及他的朋友躲到乙個洞中,39個猶太人決定寧願死...

約瑟夫問題 約瑟夫環

約瑟夫問題 有時也稱為約瑟夫斯置換,是乙個出現在電腦科學和數學中的問題。在計算機程式設計的演算法中,類似問題又稱為約瑟夫環。又稱 丟手絹問題 據說著名猶太歷史學家 josephus有過以下的故事 在羅馬人占領喬塔帕特後,39 個猶太人與josephus及他的朋友躲到乙個洞中,39個猶太人決定寧願死也...

約瑟夫環問題

約瑟夫環問題 問題描述 編號是1,2,n的n個人按照順時針方向圍坐一圈,每個人持有乙個密碼 正整數 一開始任選乙個正整數作為報數上限值m,從第乙個人開始順時針方向自1開始順序報數,報到m時停止報數。報m的人出列,將他的密碼作為新的m值,從他在順時針方向的下乙個人開始重新從1報數,如此下去,直到所有人...