包含min函式的棧 js

2021-09-23 15:41:57 字數 866 閱讀 4351

定義棧的資料結構,請在該型別中實現乙個能夠得到棧中所含最小元素的min函式(時間複雜度應為o(1))。

第一種:js陣列的一些方法

第二種:

當node < stack2的最後乙個值時,才push進來,那麼pop的時候就需要驗證stack1 pop出來的那個值是否等於stack2的最後乙個值(也就是最小值)

push進來時,無論如何都會push乙個值進stack2,node小就push node,原來的stack2最後乙個值小就push原來的最小值,這樣做的好處是pop的時候不需要判斷,直接兩個棧都pop一下就ok了,stack2上的值都是對應的stack1上的值得最小值,很方便,所以我採用了這種思路。

var stack =

;const

push

= node => stack.

push

(node)

;const

pop=()

=> stack.

pop();

const

top=()

=> stack[stack.length -1]

;const

min=()

=> math.min.

(math, stack)

;//第二種

var stack1 =

;var stack2 =

;function

push

(node)

else

else}}

function

pop(

)function

top(

)function

min(

)

js 包含min函式的棧 包含min函式的棧

目標 定義棧的資料結構,請在該型別中實現乙個能夠得到棧的最小元素的 min 函式在該棧中,呼叫 min push 及 pop 的時間複雜度都是 o 1 設計思路 我們要做的是在我們每次資料入棧的時候,記錄當前資料棧中最小值,並且在pop 出棧之後依然能找到最小值 方案 如果只用乙個 min 變數來儲...

包含min函式的棧

題目描述 定義棧的資料結構,請在該型別中實現乙個能夠得到棧最小元素的min函式。輸入 輸入可能包含多個測試樣例,輸入以eof結束。對於每個測試案例,輸入的第一行為乙個整數n 1 n 1000000 n代表將要輸入的操作的步驟數。接下來有n行,每行開始有乙個字母ci。ci s 時,接下有乙個數字k,代...

包含min函式的棧

1.問題描述 定義棧的資料結構,請在該型別中實現乙個能夠得到棧的最小元素的函式,在該棧中呼叫min,push及pop的時間複雜度都為o 1 來自 劍指offer 2.分析 我們可以使用乙個輔助棧,專門來處理題目中得到棧的最小元素的函式時間複雜度為o 1 的這個需求。當我們壓棧時,另外乙個棧正常進行,...