Merge pull request #163 from S-N-O-R-L-A-X/linkedlist_stack
Update linkedlist stack in JS and TS
This commit is contained in:
commit
a1f67c6484
89
codes/javascript/chapter_stack_and_queue/linkedlist_stack.js
Normal file
89
codes/javascript/chapter_stack_and_queue/linkedlist_stack.js
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
/**
|
||||||
|
* File: linkedlist_stack.js
|
||||||
|
* Created Time: 2022-12-22
|
||||||
|
* Author: S-N-O-R-L-A-X (snorlax.xu@outlook.com)
|
||||||
|
*/
|
||||||
|
|
||||||
|
const ListNode = require("../include/ListNode");
|
||||||
|
|
||||||
|
/* 基于链表实现的栈 */
|
||||||
|
class LinkedListStack {
|
||||||
|
#stackPeek; // 将头结点作为栈顶
|
||||||
|
#stkSize = 0; // 栈的长度
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
this.#stackPeek = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 获取栈的长度 */
|
||||||
|
get size() {
|
||||||
|
return this.#stkSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 判断栈是否为空 */
|
||||||
|
isEmpty() {
|
||||||
|
return this.size == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 入栈 */
|
||||||
|
push(num) {
|
||||||
|
const node = new ListNode(num);
|
||||||
|
node.next = this.#stackPeek;
|
||||||
|
this.#stackPeek = node;
|
||||||
|
this.#stkSize++;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 出栈 */
|
||||||
|
pop() {
|
||||||
|
const num = this.peek();
|
||||||
|
this.#stackPeek = this.#stackPeek.next;
|
||||||
|
this.#stkSize--;
|
||||||
|
return num;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 访问栈顶元素 */
|
||||||
|
peek() {
|
||||||
|
if (!this.#stackPeek)
|
||||||
|
throw new Error("栈为空!");
|
||||||
|
return this.#stackPeek.val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 将链表转化为 Array 并返回 */
|
||||||
|
toArray() {
|
||||||
|
let node = this.#stackPeek;
|
||||||
|
const res = new Array(this.size);
|
||||||
|
for (let i = res.length - 1; i >= 0; i--) {
|
||||||
|
res[i] = node.val;
|
||||||
|
node = node.next;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* 初始化栈 */
|
||||||
|
const stack = new LinkedListStack();
|
||||||
|
|
||||||
|
/* 元素入栈 */
|
||||||
|
stack.push(1);
|
||||||
|
stack.push(3);
|
||||||
|
stack.push(2);
|
||||||
|
stack.push(5);
|
||||||
|
stack.push(4);
|
||||||
|
console.log("栈 stack = " + stack.toArray());
|
||||||
|
|
||||||
|
/* 访问栈顶元素 */
|
||||||
|
const peek = stack.peek();
|
||||||
|
console.log("栈顶元素 peek = " + peek);
|
||||||
|
|
||||||
|
/* 元素出栈 */
|
||||||
|
const pop = stack.pop();
|
||||||
|
console.log("出栈元素 pop = " + pop + ",出栈后 stack = " + stack.toArray());
|
||||||
|
|
||||||
|
/* 获取栈的长度 */
|
||||||
|
const size = stack.size;
|
||||||
|
console.log("栈的长度 size = " + size);
|
||||||
|
|
||||||
|
/* 判断是否为空 */
|
||||||
|
const isEmpty = stack.isEmpty();
|
||||||
|
console.log("栈是否为空 = " + isEmpty);
|
91
codes/typescript/chapter_stack_and_queue/linkedlist_stack.ts
Normal file
91
codes/typescript/chapter_stack_and_queue/linkedlist_stack.ts
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
/**
|
||||||
|
* File: linkedlist_stack.ts
|
||||||
|
* Created Time: 2022-12-21
|
||||||
|
* Author: S-N-O-R-L-A-X (snorlax.xu@outlook.com)
|
||||||
|
*/
|
||||||
|
|
||||||
|
import ListNode from "../module/ListNode"
|
||||||
|
|
||||||
|
/* 基于链表实现的栈 */
|
||||||
|
class LinkedListStack {
|
||||||
|
private stackPeek: ListNode | null; // 将头结点作为栈顶
|
||||||
|
private stkSize: number = 0; // 栈的长度
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
this.stackPeek = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 获取栈的长度 */
|
||||||
|
get size(): number {
|
||||||
|
return this.stkSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 判断栈是否为空 */
|
||||||
|
isEmpty(): boolean {
|
||||||
|
return this.size == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 入栈 */
|
||||||
|
push(num: number): void {
|
||||||
|
const node = new ListNode(num);
|
||||||
|
node.next = this.stackPeek;
|
||||||
|
this.stackPeek = node;
|
||||||
|
this.stkSize++;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 出栈 */
|
||||||
|
pop(): number {
|
||||||
|
const num = this.peek();
|
||||||
|
if (!this.stackPeek)
|
||||||
|
throw new Error("栈为空");
|
||||||
|
this.stackPeek = this.stackPeek.next;
|
||||||
|
this.stkSize--;
|
||||||
|
return num;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 访问栈顶元素 */
|
||||||
|
peek(): number {
|
||||||
|
if (!this.stackPeek)
|
||||||
|
throw new Error("栈为空");
|
||||||
|
return this.stackPeek.val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 将链表转化为 Array 并返回 */
|
||||||
|
toArray(): number[] {
|
||||||
|
let node = this.stackPeek;
|
||||||
|
const res = new Array<number>(this.size);
|
||||||
|
for (let i = res.length - 1; i >= 0; i--) {
|
||||||
|
res[i] = node!.val;
|
||||||
|
node = node!.next;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* 初始化栈 */
|
||||||
|
const stack = new LinkedListStack();
|
||||||
|
|
||||||
|
/* 元素入栈 */
|
||||||
|
stack.push(1);
|
||||||
|
stack.push(3);
|
||||||
|
stack.push(2);
|
||||||
|
stack.push(5);
|
||||||
|
stack.push(4);
|
||||||
|
console.log("栈 stack = " + stack.toArray());
|
||||||
|
|
||||||
|
/* 访问栈顶元素 */
|
||||||
|
const peek = stack.peek();
|
||||||
|
console.log("栈顶元素 peek = " + peek);
|
||||||
|
|
||||||
|
/* 元素出栈 */
|
||||||
|
const pop = stack.pop();
|
||||||
|
console.log("出栈元素 pop = " + pop + ",出栈后 stack = " + stack.toArray());
|
||||||
|
|
||||||
|
/* 获取栈的长度 */
|
||||||
|
const size = stack.size;
|
||||||
|
console.log("栈的长度 size = " + size);
|
||||||
|
|
||||||
|
/* 判断是否为空 */
|
||||||
|
const isEmpty = stack.isEmpty();
|
||||||
|
console.log("栈是否为空 = " + isEmpty);
|
@ -390,13 +390,125 @@ comments: true
|
|||||||
=== "JavaScript"
|
=== "JavaScript"
|
||||||
|
|
||||||
```js title="linkedlist_stack.js"
|
```js title="linkedlist_stack.js"
|
||||||
|
/* 基于链表实现的栈 */
|
||||||
|
class LinkedListStack {
|
||||||
|
#stackPeek; // 将头结点作为栈顶
|
||||||
|
#stkSize = 0; // 栈的长度
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
this.#stackPeek = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 获取栈的长度 */
|
||||||
|
get size() {
|
||||||
|
return this.#stkSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 判断栈是否为空 */
|
||||||
|
isEmpty() {
|
||||||
|
return this.size == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 入栈 */
|
||||||
|
push(num) {
|
||||||
|
const node = new ListNode(num);
|
||||||
|
node.next = this.#stackPeek;
|
||||||
|
this.#stackPeek = node;
|
||||||
|
this.#stkSize++;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 出栈 */
|
||||||
|
pop() {
|
||||||
|
const num = this.peek();
|
||||||
|
if (!this.#stackPeek) {
|
||||||
|
throw new Error("栈为空!");
|
||||||
|
}
|
||||||
|
this.#stackPeek = this.#stackPeek.next;
|
||||||
|
this.#stkSize--;
|
||||||
|
return num;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 访问栈顶元素 */
|
||||||
|
peek() {
|
||||||
|
if (!this.#stackPeek) {
|
||||||
|
throw new Error("栈为空!");
|
||||||
|
}
|
||||||
|
return this.#stackPeek.val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 将链表转化为 Array 并返回 */
|
||||||
|
toArray() {
|
||||||
|
let node = this.#stackPeek;
|
||||||
|
const res = new Array(this.size);
|
||||||
|
for (let i = res.length - 1; i >= 0; i--) {
|
||||||
|
res[i] = node.val;
|
||||||
|
node = node.next;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
=== "TypeScript"
|
=== "TypeScript"
|
||||||
|
|
||||||
```typescript title="linkedlist_stack.ts"
|
```typescript title="linkedlist_stack.ts"
|
||||||
|
/* 基于链表实现的栈 */
|
||||||
|
class LinkedListStack {
|
||||||
|
private stackPeek: ListNode | null; // 将头结点作为栈顶
|
||||||
|
private stkSize: number = 0; // 栈的长度
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
this.stackPeek = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 获取栈的长度 */
|
||||||
|
get size(): number {
|
||||||
|
return this.stkSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 判断栈是否为空 */
|
||||||
|
isEmpty(): boolean {
|
||||||
|
return this.size == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 入栈 */
|
||||||
|
push(num: number): void {
|
||||||
|
const node = new ListNode(num);
|
||||||
|
node.next = this.stackPeek;
|
||||||
|
this.stackPeek = node;
|
||||||
|
this.stkSize++;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 出栈 */
|
||||||
|
pop(): number {
|
||||||
|
const num = this.peek();
|
||||||
|
if (!this.stackPeek) {
|
||||||
|
throw new Error("栈为空!");
|
||||||
|
}
|
||||||
|
this.stackPeek = this.stackPeek.next;
|
||||||
|
this.stkSize--;
|
||||||
|
return num;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 访问栈顶元素 */
|
||||||
|
peek(): number {
|
||||||
|
if (!this.stackPeek) {
|
||||||
|
throw new Error("栈为空!");
|
||||||
|
}
|
||||||
|
return this.stackPeek.val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 将链表转化为 Array 并返回 */
|
||||||
|
toArray(): number[] {
|
||||||
|
let node = this.stackPeek;
|
||||||
|
const res = new Array<number>(this.size);
|
||||||
|
for (let i = res.length - 1; i >= 0; i--) {
|
||||||
|
res[i] = node!.val;
|
||||||
|
node = node!.next;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
=== "C"
|
=== "C"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user