* feat(tools): add seed/solution restore script * chore(curriculum): remove empty sections' markers * chore(curriculum): add seed + solution to Chinese * chore: remove old formatter * fix: update getChallenges parse translated challenges separately, without reference to the source * chore(curriculum): add dashedName to English * chore(curriculum): add dashedName to Chinese * refactor: remove unused challenge property 'name' * fix: relax dashedName requirement * fix: stray tag Remove stray `pre` tag from challenge file. Signed-off-by: nhcarrigan <nhcarrigan@gmail.com> Co-authored-by: nhcarrigan <nhcarrigan@gmail.com>
161 lines
3.1 KiB
Markdown
161 lines
3.1 KiB
Markdown
---
|
||
id: 587d8250367417b2b2512c5f
|
||
title: 创建一个堆栈类
|
||
challengeType: 1
|
||
videoUrl: ''
|
||
dashedName: create-a-stack-class
|
||
---
|
||
|
||
# --description--
|
||
|
||
在上一节中,我们讨论了堆栈是什么以及如何使用数组来表示堆栈。在本节中,我们将创建自己的堆栈类。虽然您可以使用数组来创建堆栈,但有时最好限制我们对堆栈的控制量。除了`push`和`pop`方法之外,堆栈还有其他有用的方法。让我们为我们的堆栈类添加一个`peek` , `isEmpty`和`clear`方法。说明编写一个`push`方法,将元素推送到堆栈顶部,一个`pop`方法删除堆栈顶部的元素,一个`peek`堆栈中第一个元素的`peek`方法,一个`isEmpty`方法,用于检查是否存在stack是空的,是一个`clear`堆栈中所有元素的方法。通常堆栈没有这个,但我们添加了一个控制台记录集合的`print`助手方法。
|
||
|
||
# --hints--
|
||
|
||
你的`Stack`类应该有一个`push`方法。
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
var test = new Stack();
|
||
return typeof test.push === 'function';
|
||
})()
|
||
);
|
||
```
|
||
|
||
你的`Stack`类应该有一个`pop`方法。
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
var test = new Stack();
|
||
return typeof test.pop === 'function';
|
||
})()
|
||
);
|
||
```
|
||
|
||
你的`Stack`类应该有一个`peek`方法。
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
var test = new Stack();
|
||
return typeof test.peek === 'function';
|
||
})()
|
||
);
|
||
```
|
||
|
||
您的`Stack`类应该有一个`isEmpty`方法。
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
var test = new Stack();
|
||
return typeof test.isEmpty === 'function';
|
||
})()
|
||
);
|
||
```
|
||
|
||
你的`Stack`类应该有一个`clear`方法。
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
var test = new Stack();
|
||
return typeof test.clear === 'function';
|
||
})()
|
||
);
|
||
```
|
||
|
||
`peek`方法应该返回堆栈的顶部元素
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
var test = new Stack();
|
||
test.push('CS50');
|
||
return test.peek() === 'CS50';
|
||
})()
|
||
);
|
||
```
|
||
|
||
`pop`方法应该删除并返回堆栈的顶部元素
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
var test = new Stack();
|
||
test.push('CS50');
|
||
return test.pop() === 'CS50';
|
||
})()
|
||
);
|
||
```
|
||
|
||
如果堆栈不包含任何元素,则`isEmpty`方法应返回true
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
var test = new Stack();
|
||
return test.isEmpty();
|
||
})()
|
||
);
|
||
```
|
||
|
||
`clear`方法应该从堆栈中删除所有元素
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
var test = new Stack();
|
||
test.push('CS50');
|
||
test.clear();
|
||
return test.isEmpty();
|
||
})()
|
||
);
|
||
```
|
||
|
||
# --seed--
|
||
|
||
## --seed-contents--
|
||
|
||
```js
|
||
function Stack() {
|
||
var collection = [];
|
||
this.print = function() {
|
||
console.log(collection);
|
||
};
|
||
// Only change code below this line
|
||
|
||
// Only change code above this line
|
||
}
|
||
```
|
||
|
||
# --solutions--
|
||
|
||
```js
|
||
class Stack {
|
||
constructor() {
|
||
this.collection = [];
|
||
}
|
||
print() {
|
||
console.log(this.collection);
|
||
}
|
||
push(val) {
|
||
this.collection.push(val);
|
||
}
|
||
pop() {
|
||
return this.collection.pop();
|
||
}
|
||
peek() {
|
||
return this.collection[this.collection.length - 1];
|
||
}
|
||
isEmpty() {
|
||
return this.collection.length === 0;
|
||
}
|
||
clear() {
|
||
return (this.collection.length = 0);
|
||
}
|
||
}
|
||
```
|