问题描述:

  一群猴子,编号是1,2,3 …m,这群猴子(m个)按照1-m的顺序围坐一圈。从第1只开始数,每数到第n个,该猴子就要离开此圈,这样依次下来,最后一只出圈的猴子为大王。输入m和n,输出猴子离开圈子的顺序,从中也可以看出最后为大王是几号猴子。
  要求采用数组作为存储结构完成。

建立一个数组,我们用1表示该位置有猴子,用0表示该位置没有猴子,数组下标与猴子一一对应,如p[0]的值为一代表第一只猴子在圈中,p[1]的值为0代表第二只猴子不在圈中。

如果有一个猴子出圈,则将该数组元素置零,另外在报数过程中要跳过该猴子。

代码如下:

/*
Copyright (c) 2015,烟台大学计算机与控制工程学院
All righs reserved
文件名称:monkey.cpp
作者: 李哲
完成日期:2015年10月26日
问题描述:猴子选大王
程序说明:源文件
*/
#include <stdio.h>
#define MaxSize 8
void king(int m,int n)
{
int p[MaxSize];
int i,j,t;
for (i=0; i<m; i++)         //构建初始序列,记录m只猴子在圈中
p[i]=1;
t=-1;                       //首次报数将从起始位置为0,即第1只猴子开始,因为在使用p[t]前t要加1
printf("出列顺序:");
for (i=1; i<=m; i++)        //循环要执行m次,有m个猴子要出圈
{
j=1;      // j用于报数
while(j<=n)  //
{
t=(t+1)%m;        //看下一只猴子,到达最后时要折回去,所以用%m
if (p[t]==1) j++; //等同于if (p[t]==1) j++;仅当q猴子在圈中,这个位置才报数
}
p[t]=0;   //猴子出圈
printf("%d ",t+1);      //输出出圈猴子的编号
}
printf("\n");
}
int main()
{
int m,n;
scanf("%d %d", &m, &n);
king(m,n);
return 0;
}

运行结果:

*第九周*数据结构实践项目一【猴子选大王(数组)】相关推荐

  1. 第八周实践项目6 猴子选大王(数组版)

    /* *Copyright (c) 2017,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:项目6-一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m ...

  2. 第四周实践项目5 猴子选大王(循环链表)

    /* *Copyright (c) 2017,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:项目5-一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m ...

  3. 猴子选大王 java_基于java数据结构链表写的猴子选大王

    [实例简介] 基于java数据结构链表写的猴子选大王,其实就是一个约瑟夫环问题,采用java数据结构链表写的.有点小问题.当输入一只猴子,报数为1时删除会出错.没有实现动态显示猴子的添加和删除. [实 ...

  4. 数据结构上机实践第四周项目5 - 猴子选大王

    数据结构实践--猴子选大王 首先呢,小普及一下 读者:难道你当我不知道 读者想对小编说: 进入正题,项目要求如下: 一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m的顺序围坐一圈.从第1只 ...

  5. 第九周项目1——猴子选大王(数组版)

    /* * Copyright (c)2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:wu.cpp * 作    者:武昊 * 完成日期:2016年1 ...

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

    /* * Copyright (c++) 2016 烟台大学计算机学院 * All right reserved. * 文件名称:wu.cpp * 作    者: 武昊 * 完成日期:2016年9月2 ...

  7. 数据结构实践——猴子选大王

    本文针对数据结构基础系列网络课程(2):线性表的实践项目. [项目 - 猴子选大王] 一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m的顺序围坐一圈.从第1只开始数,每数到第n个,该猴子就 ...

  8. 数据结构实践——猴子选大王(数组版)

    本文针对数据结构基础系列网络课程(5): 数组与广义表的实践项目. [项目 - 猴子选大王(数组版)] 一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m的顺序围坐一圈.从第1只开始数,每数 ...

  9. 【数据结构机试复习2】 赛马 猴子选大王

    EX1:赛马 A与B之间将进行一场赛马比赛,C为裁判.A与B分别拥有n匹马,这2n匹马中每匹马拥有的能力值都不相同.比赛前,参赛的两人先决定自己的马的出场顺序:比赛时,A的第一匹马将对战B的第一匹马, ...

  10. 猴子选王c语言链表程序代码,数据结构(C语言)用栈和链表编写猴子选大王程序...

    <数据结构(C语言)用栈和链表编写猴子选大王程序>由会员分享,可在线阅读,更多相关<数据结构(C语言)用栈和链表编写猴子选大王程序(3页珍藏版)>请在人人文库网上搜索. 1.i ...

最新文章

  1. 摄像头模组(CCM)与镀膜
  2. throw和throw ex的区别
  3. SAP ABAP逻辑数据库
  4. 【转载】COM 组件设计与应用(四)——简单调用组件
  5. python同时输入多个变量_python同时给多个变量赋值|python3教程|python入门|python教程...
  6. 带有Spring的REST的ETag
  7. C#并行编程-并发集合
  8. css中属性设置成百分比
  9. B站美股增长13.24% 收盘价26.34美元创历史最高价
  10. linux文件共享之samba,nfs的搭建
  11. 【转】对Java Serializable(序列化)的理解和总结
  12. 201507152326_《Javascript实现跨域有4种方法——介绍jsonp和html5方法》
  13. 【What if 系列】危险的高压锅
  14. c 语言编程规则,C语言编程之 makfile规则.doc
  15. Activity切换闪屏问题
  16. Programming Ruby 读书笔记(三)
  17. 单周期MIPS CPU设计
  18. Google TPU edge装机
  19. 龙ol服务器维护补偿boss,总裁酷炫狂霸拽 《龙OL》练武场深处的BOSS
  20. 2020中国高校薪资排行出炉!来看看你们学校排名吧~

热门文章

  1. [置顶]       jQuery旋转插件—rotate
  2. Spring Security3
  3. Lightroom Classic 教程,如何在 Lightroom 中创建黑色电影效果?
  4. Illustrator最新教程,如何在 Illustrator 中微调图标?
  5. iOS开发之字符串(NSString)的拼接
  6. 深入浅出,解读阿里云云盾WAF防护功能
  7. python shell 方向键不可用
  8. Linux 每日一练 :cat猫 的 反义词是啥 ? 是这个tac 哇哇哇!!
  9. ORACLE EXP/IMP的使用详解 (解决9i(window)导入到10G的乱码问题)
  10. Python使用总结