javascript数据结构(栈)解决佩兹糖果盒问题
2016-06-06 14:27
369 查看
function Stack() { this.top = 0; this.dataStore = []; this.push = push; this.pop = pop; this.peek = peek; this.length = length; this.clear = clear; this.toString = toString; }; //push压栈 function push(element) { this.dataStore[this.top++] = element; }; //pop出栈 function pop() { return this.dataStore[--this.top]; }; //peek查询栈顶元素 function peek() { return this.dataStore[this.top-1]; }; //length返回栈内元素个数 function length() { return this.top; }; //clear清空栈内元素 function clear() { this.top = 0;};
var sweetBox = new Stack();
sweetBox.push('red');
sweetBox.push('yellow');
sweetBox.push('red');
sweetBox.push('yellow');
sweetBox.push('red');
sweetBox.push('white');
sweetBox.push('yellow');
sweetBox.push('white');
sweetBox.push('yellow');
sweetBox.push('white');
sweetBox.push('red');
//取出不喜欢的颜色 get
function getColor(element,stack) {
var getColorStack = new Stack();
var setColorStack = new Stack();
while(stack.length()>0){
if(stack.peek() == element){
getColorStack.push(element);
stack.pop();
}else{
setColorStack.push(stack.peek());
stack.pop();
}
}
while (setColorStack.length()>0){
stack.push(setColorStack.peek());
setColorStack.pop();
}
console.log(stack.peek());
}
getColor('red',sweetBox);
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解
- call/apply/bind 的理解与实例分享