击鼓传花击鼓次数相同c语言,JavaScript 实现击鼓传花游戏

大家小时候应该都玩过击鼓传花(Hot Potato)的游戏吧!

一群小孩围成一个圆圈,把花尽快的传给旁边的人。某一时刻传花停止,这时花在谁手里,谁就退出圆圈结束游戏。重复此过程,直到剩下最后一个孩子,即为胜者。

如何用 JavaScript 代码按此规则实现击鼓传花呢?

这里需要借助 JavaScript 中队列的知识,利用循环队列来实现。

6d99ffa9d44a

队列

首先,我们创建一个 queue.js 的文件存储 Queue 类,代码如下:

export default class Queue {

constructor() {

this.count = 0;

this.lowestCount = 0;

this.items = {};

}

enqueue(element) {

this.items[this.count] = element;

this.count++;

}

dequeue() {

if (this.isEmpty()) {

return undefined;

}

const result = this.items[this.lowestCount];

delete this.items[this.lowestCount];

this.lowestCount++;

return result;

}

isEmpty() {

return this.size() === 0;

}

clear() {

this.items = {};

this.count = 0;

this.lowestCount = 0;

}

size() {

return this.count - this.lowestCount;

}

toString() {

if (this.isEmpty()) {

return '';

}

let objString = `${this.items[this.lowestCount]}`;

for (let i = this.lowestCount + 1; i < this.count; i++) {

objString = `${objString},${this.items[i]}`;

}

return objString;

}

}

其次,根据击鼓传花的规则和循环队列的知识,组织代码:

/**

* @param {Array:参加游戏的人员} elementsList

* @param {number:每次击鼓的次数} num

*/

function hotPotato(elementsList, num) {

// 引入 queue.js 创建 Queue 实例

const queue = new Queue();

const elimitatedList = [];

for (let i = 0; i < elementsList.length; i++) {

// 把参加的人列入队列中

queue.enqueue(elementsList[i]);

}

while (queue.size() > 1) {

for (let i = 0; i < num; i++) {

// 把队列的第一个人放入队尾循环队列

queue.enqueue(queue.dequeue());

}

// 把淘汰的人放入 elimitatedList 数组中

elimitatedList.push(queue.dequeue());

}

return {

eliminated: elimitatedList, // 淘汰的人

winner: queue.dequeue() // 胜利者

};

}

// test

const names = ['丁一', '龙二', '张三', '李四', '王五', '赵六'];

const result = hotPotato(names, 7);

result.eliminated.forEach(name => {

console.log(`${name} was eliminated from the Hot Potato game.`);

});

console.log(`The winner is: ${result.winner}`);

// 龙二 was eliminated from the Hot Potato game.

// 王五 was eliminated from the Hot Potato game.

// 李四 was eliminated from the Hot Potato game.

// 丁一 was eliminated from the Hot Potato game.

// 赵六 was eliminated from the Hot Potato game.

// The winner is: 张三

输出的结果依次为被淘汰的选手和最后的胜利者,这个方法有个弊病:每次淘汰选手敲得鼓声都是一样,导致淘汰的选手和胜利者能预测到。一般我们游戏的时候敲的鼓声都是不确定的,那如何做到不确定,达到一定的游戏氛围呢?大家集思广益吧!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/382946.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言查找字符串au,几个C语言词汇不懂,望老鸟们相助(俺是新手哦)

几个C语言词汇 auto break case char const continue default do double else enum extern float for goto if int long registerreturn short signed几个C语言词汇 auto break case char const continue default do double else enum extern float for goto if int long regis…

c语言中 %.2s,C2S是什么意思

1. The testing result indicates that TiO_2 has mineralized effect on C_2S, at the same time flux effect on reducing low general melting point of CaO-SiO_2 system and yielding much liquid phase, TiO_2 has definite stabilized effect on β-C_2S.结果随着TiO2掺…

前端的c语言面试题,前端工程师面试题汇总(选择题)

前端工程师面试题汇总(选择题)时间&#xff1a;2017-12-05 来源&#xff1a;前端工程师面试题推荐作为一名前端工程师&#xff0c;我们必不可少的就是参加面试&#xff0c;面试过程中会遇到各类奇葩的问题&#xff0c;今天小编为大家汇总了一些相关的问题&#xff0c;希望可…

用英文单词模拟数字计算c语言,C语言程序设计用英文单词模拟数学计算

匿名用户1级2010-05-09 回答最后输出是用的是阿拉伯数字&#xff0c;这个你再改改吧&#xff0c; 小问题了。。。。#include #include #include #include #include int carry 0;int parse_int(const char *s, int len){char tens[10], units[10];memset(tens, 0, sizeof(tens)…

c语言猜数字游戏新建,C语言编程 如何构建一个简单的猜数字小游戏

#include//生成随机函数起点时用到time.hint main(){int number1 0, choice 0, number2 0;printf("$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$\n");//界面设置printf("$$$$$ 欢 迎 来 到 $$$$$\n");printf("$$$$$ 猜 数 字 …

c语言循环拆分成和,C语言拆分循环链表程序

创建一个循环链表&#xff0c;并将这个循环链表拆分成为两个循环链表的示例程序&#xff0c;将以下代码保存到一个源文件中&#xff1a;split_circular_linked_list.c&#xff0c; 如下所示 –#include #include struct node { int data; struct node *next; }; struct node *e…

pic单片机c语言读eeprom,PIC16F877单片机内部EEPROM读写实例

;PIC16F877单片机内部EEPROM读写实例****************************************************************************************; This is a program to test the function of reading&writting for EEPROM.; YouCANOBServe the value of register(30H--?) buy changin…

C语言运行gis空间叠加分析,GIS空间叠加分析与缓冲区分析.doc

《地理信息系统》报告专 业 资源环境与城乡规划管理 姓 名 成 绩班 级 学 号 日 期 2014/6/20目录TOC \o "1-2" \h \u 14469 一、题目 23290 二、设计目的27200 三、设计背景2四、设计内容27200 四、步骤与过程27200 五、专题地图 37521 四、总结分析 9题目佛山市顺德…

组件文件已损坏或android内部模块,android - Android Q更新后,模块化系统组件在托管配置文件中不可用 - 堆栈内存溢出...

在从工作配置文件配置的设备设置应用中将操作系统从Android 9升级到10后&#xff0c;请停止运行。java.lang.RuntimeException: Unable to start activity ComponentInfo{com.android.settings/com.android.settings.applications.InstalledAppDetailsTop}: java.lang.NullPoin…

android文本复制自定义剪切板,android 剪切板-文本复制、粘贴

1. 粘贴&#xff0d;文本保存到剪切板中ClipboardManager clipboardManager (ClipboardManager) context.getSystemService(Context.CLIPBOARD_SERVICE);//创建ClipData对象ClipData clipData ClipData.newPlainText("orderNo", txt);//添加ClipData对象到剪切板中…

android保持服务不休眠,Android开发保持屏幕常亮和CPU不休眠唤醒状态

安卓手机 APP 开发&#xff0c;有的时候需要屏幕长时间亮着&#xff0c;也就是不锁屏&#xff0c;这时CPU会一直处于不休眠唤醒状态。下面介绍两种方法。方法一&#xff1a;通过 PowerManager 实现。此种方法会在软件安装时用户可以看到屏幕选项。首先&#xff0c;在 AndroidMa…

android 磁场传感器 罗盘,Android开发获取重力加速度和磁场强度的方法

本文实例讲述了Android开发获取重力加速度和磁场强度的方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;Android获取重力加速度和磁场强度主要依靠&#xff1a;Sensor.getRotationMatrix (float[] R, float[] I, float[] gravity, float[] geomagnetic)输入数据&am…

android spinner位置,在Android中的Spinner中没有选择位置0

我创建了一个有三个项目的微调器日常每周每月一次我在我的java文件中执行了以下操作&#xff1a;navSpinner new ArrayList();navSpinner.add(new SpinnerNavItem(getResources().getString(R.string.dailyview)));navSpinner.add(new SpinnerNavItem(getResources().getStrin…

android tombstone发生过程,Android Tombstone解决步骤

这周和同事一起解了个tombstone的bug, 记录下分析的过程&#xff0c;免得以后又忘记。。。1>log的分析pid: 122, tid: 14745, name: Binder_2 >>> /system/bin/mediaserver <<<signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 00000058eax 00000…

优酷android手机客户端for,优酷手机客户端

优酷手机客户端官方最新版是官方出品的最新版播放软件&#xff0c;该软件上面汇聚了其他视频app上没有的精彩节目&#xff0c;全国各大精彩剧集与电影免费首播&#xff0c;更有独特高清蓝光画质播放&#xff0c;想要体验的朋友可以来欣赏一下!软件特点1、高清流畅播放2、国内外…

html在线编辑器 asp.net,ASP.NET网站使用Kindeditor富文本编辑器配置步骤

1. 下载编辑器下载 KindEditor 最新版本&#xff0c;下载页面: http://www.kindsoft.net/down.php2. 部署编辑器解压 kindeditor-x.x.x.zip 文件&#xff0c;将editor文件夹复制到web目录下3、在网页中加入(ValidateRequest"false")4、引入脚本文件(XXX部分需要修改)…

html表格中绑定显示xml文档内容的简单实例,JS读取XML文件数据并以table形式显示数据的方法(兼容IE与火狐)...

本文实例讲述了JS读取XML文件数据并以table形式显示数据的方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;先看xml文件&#xff1a;张秋丽女 18李文才男 31李斯文男 22马英女 25孙红雷男 32欧阳俊雄男 28江琳女 23小小女 22aspx页面代码&#xff1a;function load…

html中通过定位 实现下拉,JS+CSS相对定位实现的下拉菜单

本文实例讲述了JSCSS相对定位实现的下拉菜单。分享给大家供大家参考。具体如下&#xff1a;这里使用的是相对定位&#xff0c;不过效果还可以&#xff0c;用时候再修整一下&#xff0c;这个只是实现了大概功能&#xff0c;还有许多细节没有修饰。运行效果截图如下&#xff1a;在…

html页面包含头文件,Web前端技术:HTML部分---Head标签中包含的头文件标签,body标签包含的内部标签...

1、Head标签中包含的 头文件标签的作用&#xff1a;(1)title标签&#xff1a;定义网页的标题。(2)meta标签&#xff1a;一般用于定义页面的特殊信息&#xff0c;例如页面的关键字、页面描述等(3)link标签&#xff1a;用于引入外部样式文件(CSS 文件)。(4)style标签&#xff1a;…

爬虫图片href是html图片,xpath爬虫实例,爬取图片网站百度盘地址和提取码

某套图网站&#xff0c;套图以封面形式展现在页面&#xff0c;需要依次点击套图&#xff0c;点击广告盘链接&#xff0c;最后到达百度网盘展示页面。这一过程通过爬虫来实现&#xff0c;收集百度网盘地址和提取码&#xff0c;采用xpath爬虫技术1、首先分析图片列表页&#xff0…