代码拉取完成,页面将自动刷新
/**
* 示例一: 基础使用
*/
// 1. 封装队列类(基于数组形式) 先进先出
function Queue() {
this.items = []
Queue.prototype.enqueue = function (element) {
this.items.push(element)
}
Queue.prototype.dequeue = function () {
return this.items.shift()
}
Queue.prototype.front = function () {
return this.items[0]
}
Queue.prototype.isEmpty = function () {
return this.items.length == 0
}
Queue.prototype.size = function () {
return this.items.length
}
Queue.prototype.toString = function () {
var itemsToString = ''
this.items.forEach(item => {
itemsToString += item + ','
});
return itemsToString
}
}
// 2. 队列使用
var queue = new Queue()
queue.enqueue('abc')
queue.enqueue('def')
queue.enqueue('ghj')
console.log(queue) // Queue { items: [ 'abc', 'def', 'ghj' ] }
queue.dequeue()
console.log(queue) // Queue { items: [ 'def', 'ghj' ] }
console.log(queue.front()) // def
console.log(queue.isEmpty()) // false
console.log(queue.toString()) // def,ghj,
/**
* 示例二: 击鼓传花
*/
function PassGame(NameList, num) {
// NameList: 参与游戏的人员
// num: 指定游戏中被淘汰的个数
var q = new Queue()
// 1. 将所有人加入到队列中
NameList.forEach(item => {
q.enqueue(item)
})
// 2. 开始游戏
while (q.size() > 1) {
// 将被指定的人删除且将他之前的元素加入到队列中
for(i = 0; i < num - 1; i++) {
q.enqueue(q.dequeue())
}
q.dequeue()
}
return '获胜的人是:' + q.front()
}
gameNames = ['lilei', 'zhangsan', 'wangwu', 'hanmeimei', 'hanxin']
console.log(PassGame(gameNames, 3)) // 获胜的人是:hanmeimei
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。