第四周 項目五【猴子選大王】


/*     
Copyright (c)2016,煙臺大學計算機與控制工程學院     
All rights reserved.     
文件名稱:項目5--猴子選大王.cpp     
作    者:梁凱 
完成日期:2016年9月22日     
版 本 號:v1.0     
     
問題描述:一羣猴子,編號是1,2,3 …m,這羣猴子(m個)按照1-m的順序圍坐一圈。
    從第1只開始數,每數到第n個,該猴子就要離開此圈,這樣依次下來,直到
    圈中只剩下最後一隻猴子,則該猴子爲大王。輸入m和n,輸出爲大王的猴子是幾號。
輸入描述:m個猴子和要出去的位數n。   
程序輸出:king是誰。
*/

//C++ 程序代碼
#include <iostream>
using namespace std;
struct Monkey
{
    int num;  //猴子的編號
    struct Monkey *next; //下一隻猴子
};

int main()
{
    int m,n,i,j,king;
    Monkey *head, *p1,*p2;
    cin>>m>>n;
    if(n==1)
    {
        king=m;
    }
    else
    {
        //建立猴子圍成的圓圈
        p1=p2=new Monkey;
        head = p1;
        head->num=1;
        for(i=1,p1->num=1; i<m; i++)  //其餘m-1只猴子
        {
            p1=new Monkey;  //p1是新增加的
            p1->num=i+1;
            p2->next=p1;
            p2=p1;          //p2總是上一隻
        }
        p2->next=head;      //最後一隻再指向第一隻,成了一個圓圈

        //下面要開始數了
        p1=head;
        for(i=1; i<m; i++)  //循環m-1次,淘汰m-1只猴子
        {
            //從p1開始,數n-1只就找到第n只了
            for(j=1; j<n-1; j++)  //實際先找到第n-1只,下一隻將是被淘汰的
                p1=p1->next;    //圍成圈的,可能再開始從第一隻數,如果還未被淘汰的話

            //找到了,
            p2=p1->next;  //p2將被刪除
            //cout<<"第"<<i<<"輪淘汰"<<p2->num<<endl;   //可以這樣觀察中間結果
            p1->next=p2->next;  //p2就這樣被“架空了”
            p1=p2->next;  //下一輪數數的新起點
            delete p2;  //將不在鏈表中的結點放棄掉
        }
        king=p1->num;
        delete p1;
    }
    cout<<king<<endl;
    return 0;
}

 運行結果:

知識點總結:

         約瑟夫問題的發現

心得體會:

        上學期在C++中就出現了這樣的題,當時不會,現在就可以看懂啦

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章