偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

我們一起聊聊包含min函數(shù)的棧

開發(fā) 前端
相信大多數(shù)開發(fā)者看到這個(gè)問題,第一反應(yīng)可能是每次往棧中壓入一個(gè)新元素時(shí),將棧里的所有元素排序,讓最小的元素位于棧頂,這樣就能在O(1)的時(shí)間內(nèi)得到最小元素了。但這種思路不能保證最后入棧的元素能夠最先出棧,因此這個(gè)思路行不通。

前言

基于數(shù)據(jù)結(jié)構(gòu): “?!保瑢?shí)現(xiàn)一個(gè)min函數(shù),調(diào)用此函數(shù)即可獲取棧中的最小元素。在該棧中,調(diào)用min、push、pop的時(shí)間復(fù)雜度都是O(1)。

思路梳理

相信大多數(shù)開發(fā)者看到這個(gè)問題,第一反應(yīng)可能是每次往棧中壓入一個(gè)新元素時(shí),將棧里的所有元素排序,讓最小的元素位于棧頂,這樣就能在O(1)的時(shí)間內(nèi)得到最小元素了。但這種思路不能保證最后入棧的元素能夠最先出棧,因此這個(gè)思路行不通。

緊接著,我們可能會(huì)想到用一個(gè)變量來存放最小的元素,每次壓入一個(gè)新元素入棧時(shí),如果它比當(dāng)前最小的元素還要小,則更新最小元素。這樣子做目的是達(dá)到了,但是又會(huì)有另一個(gè)問題:如果當(dāng)前最小元素被彈出棧了,那么如何得到下一個(gè)最小的元素?

很顯然,我們僅僅添加一個(gè)變量用來存儲(chǔ)最小元素是不夠的,也就是說當(dāng)最小元素被取出時(shí),我們希望得到次最小元素。那么,我們能否用一個(gè)輔助棧專門來存放這些最小元素呢?當(dāng)元素入棧時(shí),我們就取出輔助棧中的棧頂元素將其與新加入元素做大小比較,把較小的一方壓入輔助棧中。

我們通過一個(gè)例子來講解下這個(gè)過程,如下所示:

const stack = [
3,
5,
7
12,
1,
9,
0
]

入棧過程如下圖所示:

圖片

出棧時(shí),我們同時(shí)彈出兩個(gè)棧的棧頂元素,獲取最小元素時(shí),我們將輔助棧的棧頂元素返回即可,過程如下圖所示:

圖片

實(shí)現(xiàn)代碼

經(jīng)過前面的分析,我們已經(jīng)得出了完整的思路,接下來就是編碼環(huán)節(jié)了,如下所示:

export class StackContainingMinFunction extends Stack {
private minStack: Stack;
private dataStack: Stack;

constructor() {
super();
this.minStack = new Stack();
this.dataStack = new Stack();
}

public push(item: number): void {
this.dataStack.push(item);
if (this.minStack.size() > 0) {
const minVal = this.minStack.peek();
// 比較當(dāng)前入棧元素與minStack中的最小元素,將小的一方入minStack
item > minVal ? this.minStack.push(minVal) : this.minStack.push(item);
return;
}
this.minStack.push(item);
}

public pop(): void {
this.minStack.pop();
this.dataStack.pop();
}

public min(): number | null {
if (this.minStack.size() > 0) return this.minStack.peek();
return null;
}
}

注意:上述代碼繼承了Stack,我們?cè)谥拔恼轮幸呀?jīng)實(shí)現(xiàn)了它,對(duì)此感興趣的開發(fā)者請(qǐng)移步:數(shù)組實(shí)現(xiàn)棧與對(duì)象實(shí)現(xiàn)棧的區(qū)別

我們將上個(gè)章節(jié)的例子代入上述實(shí)現(xiàn)的函數(shù)中,來看下它能否正確運(yùn)行。

const stackMinFn = new StackContainingMinFunction();
stackMinFn.push(3);
stackMinFn.push(5);
stackMinFn.push(7);
stackMinFn.push(12);
stackMinFn.push(1);
stackMinFn.push(9);
stackMinFn.push(0);
stackMinFn.pop();
stackMinFn.pop();
stackMinFn.pop();
console.log("當(dāng)前棧內(nèi)最小值為:", stackMinFn.min());

圖片

示例代碼

本文所列舉的代碼完整版請(qǐng)移步:

  • StackContainingMinFunction.ts
  • stackContainingMinFunction-test.ts
責(zé)任編輯:武曉燕 來源: 神奇的程序員
相關(guān)推薦

2023-12-28 09:55:08

隊(duì)列數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)

2022-04-06 08:23:57

指針函數(shù)代碼

2023-04-26 07:30:00

promptUI非結(jié)構(gòu)化

2021-08-27 07:06:10

IOJava抽象

2024-02-20 21:34:16

循環(huán)GolangGo

2022-10-08 00:00:05

SQL機(jī)制結(jié)構(gòu)

2023-08-04 08:20:56

DockerfileDocker工具

2023-08-10 08:28:46

網(wǎng)絡(luò)編程通信

2022-05-24 08:21:16

數(shù)據(jù)安全API

2023-09-10 21:42:31

2023-06-30 08:18:51

敏捷開發(fā)模式

2023-03-07 07:05:29

生產(chǎn)數(shù)據(jù)庫(kù)運(yùn)維

2021-07-31 11:40:55

Openresty開源

2022-02-14 07:03:31

網(wǎng)站安全MFA

2024-02-26 00:00:00

Go性能工具

2022-11-12 12:33:38

CSS預(yù)處理器Sass

2022-12-07 13:12:15

2022-01-04 12:08:46

設(shè)計(jì)接口

2025-03-27 02:00:00

SPIJava接口

2022-07-29 08:17:46

Java對(duì)象內(nèi)存
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)