*第九周*数据结构实践项目一【猴子选大王(数组)】
问题描述:
一群猴子,编号是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;
}
运行结果:
*第九周*数据结构实践项目一【猴子选大王(数组)】相关推荐
- 第八周实践项目6 猴子选大王(数组版)
/* *Copyright (c) 2017,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:项目6-一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m ...
- 第四周实践项目5 猴子选大王(循环链表)
/* *Copyright (c) 2017,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:项目5-一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m ...
- 猴子选大王 java_基于java数据结构链表写的猴子选大王
[实例简介] 基于java数据结构链表写的猴子选大王,其实就是一个约瑟夫环问题,采用java数据结构链表写的.有点小问题.当输入一只猴子,报数为1时删除会出错.没有实现动态显示猴子的添加和删除. [实 ...
- 数据结构上机实践第四周项目5 - 猴子选大王
数据结构实践--猴子选大王 首先呢,小普及一下 读者:难道你当我不知道 读者想对小编说: 进入正题,项目要求如下: 一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m的顺序围坐一圈.从第1只 ...
- 第九周项目1——猴子选大王(数组版)
/* * Copyright (c)2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:wu.cpp * 作 者:武昊 * 完成日期:2016年1 ...
- 第四周项目5——猴子选大王
/* * Copyright (c++) 2016 烟台大学计算机学院 * All right reserved. * 文件名称:wu.cpp * 作 者: 武昊 * 完成日期:2016年9月2 ...
- 数据结构实践——猴子选大王
本文针对数据结构基础系列网络课程(2):线性表的实践项目. [项目 - 猴子选大王] 一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m的顺序围坐一圈.从第1只开始数,每数到第n个,该猴子就 ...
- 数据结构实践——猴子选大王(数组版)
本文针对数据结构基础系列网络课程(5): 数组与广义表的实践项目. [项目 - 猴子选大王(数组版)] 一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m的顺序围坐一圈.从第1只开始数,每数 ...
- 【数据结构机试复习2】 赛马 猴子选大王
EX1:赛马 A与B之间将进行一场赛马比赛,C为裁判.A与B分别拥有n匹马,这2n匹马中每匹马拥有的能力值都不相同.比赛前,参赛的两人先决定自己的马的出场顺序:比赛时,A的第一匹马将对战B的第一匹马, ...
- 猴子选王c语言链表程序代码,数据结构(C语言)用栈和链表编写猴子选大王程序...
<数据结构(C语言)用栈和链表编写猴子选大王程序>由会员分享,可在线阅读,更多相关<数据结构(C语言)用栈和链表编写猴子选大王程序(3页珍藏版)>请在人人文库网上搜索. 1.i ...
最新文章
- 摄像头模组(CCM)与镀膜
- throw和throw ex的区别
- SAP ABAP逻辑数据库
- 【转载】COM 组件设计与应用(四)——简单调用组件
- python同时输入多个变量_python同时给多个变量赋值|python3教程|python入门|python教程...
- 带有Spring的REST的ETag
- C#并行编程-并发集合
- css中属性设置成百分比
- B站美股增长13.24% 收盘价26.34美元创历史最高价
- linux文件共享之samba,nfs的搭建
- 【转】对Java Serializable(序列化)的理解和总结
- 201507152326_《Javascript实现跨域有4种方法——介绍jsonp和html5方法》
- 【What if 系列】危险的高压锅
- c 语言编程规则,C语言编程之 makfile规则.doc
- Activity切换闪屏问题
- Programming Ruby 读书笔记(三)
- 单周期MIPS CPU设计
- Google TPU edge装机
- 龙ol服务器维护补偿boss,总裁酷炫狂霸拽 《龙OL》练武场深处的BOSS
- 2020中国高校薪资排行出炉!来看看你们学校排名吧~
热门文章
- [置顶] jQuery旋转插件—rotate
- Spring Security3
- Lightroom Classic 教程,如何在 Lightroom 中创建黑色电影效果?
- Illustrator最新教程,如何在 Illustrator 中微调图标?
- iOS开发之字符串(NSString)的拼接
- 深入浅出,解读阿里云云盾WAF防护功能
- python shell 方向键不可用
- Linux 每日一练 :cat猫 的 反义词是啥 ? 是这个tac 哇哇哇!!
- ORACLE EXP/IMP的使用详解 (解决9i(window)导入到10G的乱码问题)
- Python使用总结