第四周项目5——猴子选大王

来源:互联网 发布:冒泡排序c语言详解 编辑:程序博客网 时间:2024/05/22 03:29
/*  
* Copyright (c)2016,烟台大学计算机与控制工程学院  
* All rights reserved.  
* 文件名称:项目5.cpp  
* 作    者:孟晔 
* 完成日期:2016年9月23日  
* 版 本 号:v1.0   
*问题描述:一群猴子,编号是1,2,3 …m,这群猴子(m个)按照1-m的顺序围坐一圈。 
          从第1只开始数,每数到第n个,该猴子就要离开此圈,这样依次下来,直到 
          圈中只剩下最后一只猴子,则该猴子为大王。输入m和n,输出为大王的猴子是几号。 
*输入描述:猴子的个数m和每次数到的数n   
*程序输出:大王的猴子是几号。   

*/   

 #include <iostream>  
using namespace std;  
struct Monkey  
{  
    int num;  //猴子的编号  
    struct Monkey *next; //下一只猴子  
};  
  
int main()  
{  
    int m,n,i,j,king;  
    Monkey *head, *p1,*p2;  
    cout<<"猴子的数量:"<<endl;  
    cin>>m;  
    cout<<"每次数到的数是:"<<endl;  
    cin>>n;  
    if(n==1)  
    {  
        king=m;  
    }  
    else  
    {  
        //建立猴子围成的圆圈  
        p1=p2=new Monkey;  
        head = p1;  
        p1->num=1;  
        for(i=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;  
}  



知识点总结:
   利用了约瑟夫问题中的方法来解决此问题。
学习心得:
 之前做过一个这样的题,不会

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 红米note3屏幕裂了怎么办 小米3屏幕烂了怎么办 苹果x屏幕触屏不灵怎么办 票买好了身份证丢了怎么办 广发信用卡身份证到期了怎么办 人在外地身份证丢了怎么办 人在国外身份证丢了怎么办 身份证丢了户口本不在怎么办 在北京身份证过期了怎么办 没社保卡怎么办厦门健康卡 扬州市民卡丢了怎么办 扬州市民卡坏了怎么办 重庆社保卡坏了怎么办 社保卡丢了看病怎么办 社保卡丢了买药怎么办 常州社保卡丢了怎么办 深圳社保卡掉了怎么办 上海医保卡丢了怎么办 户口转到西安后医保怎么办 上海医保卡掉了怎么办 上海医保本丢了怎么办? 新版医保卡丢了怎么办 武汉社保卡掉了怎么办 职工社保卡丢了怎么办 杭州社保卡丢了怎么办 农村医疗卡丢了怎么办 陕西省医保卡丢了怎么办 小孩社保卡掉了怎么办 社区医保本丢了怎么办 宝宝医保卡掉了怎么办 同煤医疗卡丢了怎么办 杭州医保卡丢了怎么办 新的医保卡丢了怎么办 二代医保卡丢了怎么办 老医保卡丢了怎么办 上海医保卡余额用完了怎么办 身份证丢了医疗报销怎么办 取公积金身份证丢了怎么办 身份证丢了怎么办就诊卡 人在外地怎么办农村社保卡 武汉医保卡丢了怎么办