chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

LeetCode初級(jí)算法-設(shè)計(jì)問題02:最小棧

電子設(shè)計(jì) ? 來源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2020-12-10 22:21 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

LeetCode初級(jí)算法--設(shè)計(jì)問題02:最小棧

一、引子

這是由LeetCode官方推出的的經(jīng)典面試題目清單~
這個(gè)模塊對(duì)應(yīng)的是探索的初級(jí)算法~旨在幫助入門算法。我們第一遍刷的是leetcode推薦的題目。

二、題目

設(shè)計(jì)一個(gè)支持 push,pop,top 操作,并能在常數(shù)時(shí)間內(nèi)檢索到最小元素的棧。

  • push(x) -- 將元素 x 推入棧中。
  • pop() -- 刪除棧頂?shù)脑亍?/li>
  • top() -- 獲取棧頂元素。
  • getMin() -- 檢索棧中的最小元素。

示例:

MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin();   --> 返回 -3.
minStack.pop();
minStack.top();      --> 返回 0.
minStack.getMin();   --> 返回 -2.

1、思路

第一種方法:

用列表模擬棧,push、pop、top和getMin分別對(duì)應(yīng)list.append()、list.pop()、list[-1]和min()操作

第二種方法:

引入minStack列表存放最小值

2、編程實(shí)現(xiàn)

第一種方法:

python

class MinStack(object):

    def __init__(self):
        """
        initialize your data structure here.
        """
        self.l = []
        

    def push(self, x):
        """
        :type x: int
        :rtype: None
        """
        if x is None:
            pass
        else:
            self.l.append(x)
        

    def pop(self):
        """
        :rtype: None
        """
        if self.l is None:
            return 'error'
        else:
            self.l.pop(-1)
        

    def top(self):
        """
        :rtype: int
        """
        if self.l is None:
            return 'error'
        else:
            return self.l[-1]
        

    def getMin(self):
        """
        :rtype: int
        """
        if self.l is None:
            return 'error'
        else:
            return min(self.l)


# Your MinStack object will be instantiated and called as such:
# obj = MinStack()
# obj.push(x)
# obj.pop()
# param_3 = obj.top()
# param_4 = obj.getMin()

第二種方法:

class MinStack(object):
 
    def __init__(self):
        """
        initialize your data structure here.
        """
        self.stack = []       #存放所有元素
        self.minStack = []#存放每一次壓入數(shù)據(jù)時(shí),棧中的最小值(如果壓入數(shù)據(jù)的值大于棧中的最小值就不需要重復(fù)壓入最小值,小于或者等于棧中最小值則需要壓入)
 
    def push(self, x):
        """
        :type x: int
        :rtype: void
        """
        self.stack.append(x)
        if not self.minStack or self.minStack[-1]>=x:
            self.minStack.append(x)
 
    def pop(self):   #移除棧頂元素時(shí),判斷是否移除棧中最小值
        """
        :rtype: void
        """
        if self.minStack[-1]==self.stack[-1]:
            del self.minStack[-1]
        self.stack.pop()
 
    def top(self):
        """
        :rtype: int
        """
        return self.stack[-1]
        
    def getMin(self):
        """
        :rtype: int
        """
        return self.minStack[-1]

本文由博客一文多發(fā)平臺(tái) OpenWrite 發(fā)布!

審核編輯 黃昊宇
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 人工智能
    +關(guān)注

    關(guān)注

    1813

    文章

    49713

    瀏覽量

    261287
  • 機(jī)器學(xué)習(xí)

    關(guān)注

    66

    文章

    8541

    瀏覽量

    136209
  • 深度學(xué)習(xí)
    +關(guān)注

    關(guān)注

    73

    文章

    5589

    瀏覽量

    123884
  • leetcode
    +關(guān)注

    關(guān)注

    0

    文章

    20

    瀏覽量

    2514
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    Stack到底用來干嘛的呢?

    Stack_Size就是大小,0x00000400就是代表有1K(0x400/1024)的大小。 那這個(gè)到底用來干嘛的呢? 比如說我們函數(shù)的形參、以及函數(shù)里定義的局部變量就是存儲(chǔ)在里,所以
    發(fā)表于 12-01 08:04

    堆和的區(qū)別

    一個(gè)由C/C 編譯的程序占用的內(nèi)存分為以下幾個(gè)部分: 區(qū)(stack):由編譯器自動(dòng)分配釋放 ,存放函數(shù)的參數(shù)值,局部變量的值等。其操作方式類似于數(shù)據(jù)結(jié)構(gòu)中的。 堆區(qū)(heap):一般由
    的頭像 發(fā)表于 11-27 18:13 ?887次閱讀

    基于E203 RISC-V的音頻信號(hào)處理系統(tǒng) -ANC算法簡(jiǎn)介

    基于FxLMS算法的寬帶前饋型主動(dòng)噪聲控制系統(tǒng)框圖 其中控制器部分,即是我們算法的核心運(yùn)算部分,即LMS算法。通過該算法對(duì)初級(jí)聲源的處理
    發(fā)表于 10-28 07:50

    TPS62A02/TPS62A02A評(píng)估模塊(EVM)技術(shù)解析與應(yīng)用指南

    Texas Instruments TPS62A02EVM/TPS62A02AEVM評(píng)估模塊配置用于評(píng)估TPS62A02和TPS62A02A的運(yùn)行。TPS62A
    的頭像 發(fā)表于 09-12 15:23 ?625次閱讀
    TPS62A<b class='flag-5'>02</b>/TPS62A<b class='flag-5'>02</b>A評(píng)估模塊(EVM)技術(shù)解析與應(yīng)用指南

    黑芝麻智能端到端全式輔助駕駛系統(tǒng)的應(yīng)用場(chǎng)景

    黑芝麻智能推出的全新一代端到端全輔助駕駛系統(tǒng),以武當(dāng)C1200系列高算力芯片為基石,深度融合自研感知算法,實(shí)現(xiàn)從場(chǎng)景感知到車輛控制的完全閉環(huán)優(yōu)化——讓輔助駕駛系統(tǒng)學(xué)會(huì)理解路況的呼吸與脈搏,真正走進(jìn)“人車共駕”的黃金時(shí)代。
    的頭像 發(fā)表于 09-09 17:19 ?2077次閱讀

    自動(dòng)駕駛中常提的“全”是個(gè)啥?有必要“全”嗎?

    和應(yīng)用,涵蓋從底層硬件、感知算法、高精地圖、定位與融合,到?jīng)Q策規(guī)劃、控制執(zhí)行、軟件平臺(tái),乃至整車集成與云端服務(wù)的完整鏈條。對(duì)于希望在激烈的市場(chǎng)競(jìng)爭(zhēng)中占據(jù)一席之地的車企和科技公司來說,全似乎代表了掌握核心競(jìng)爭(zhēng)
    的頭像 發(fā)表于 08-27 09:43 ?652次閱讀
    自動(dòng)駕駛中常提的“全<b class='flag-5'>棧</b>”是個(gè)啥?有必要“全<b class='flag-5'>棧</b>”嗎?

    ?REF02 精密電壓參考芯片技術(shù)文檔總結(jié)

    的影響最小。REF02 采用單電源供電,輸入范圍為 8V 至 40V,電流消耗極低,僅為 1mA,并且由于改進(jìn)的設(shè)計(jì)而具有出色的溫度穩(wěn)定性。出色的線路和負(fù)載調(diào)節(jié)、低噪聲、低功耗和低成本使 REF02
    的頭像 發(fā)表于 08-15 11:15 ?896次閱讀
    ?REF<b class='flag-5'>02</b> 精密電壓參考芯片技術(shù)文檔總結(jié)

    RISC-V架構(gòu)下AI融合算力及其軟件實(shí)踐

    。目前,進(jìn)迭時(shí)空已經(jīng)取得了顯著的進(jìn)展,成功推出了第一個(gè)版本的智算核(帶AI融合算力的智算CPU)以及配套的AI軟件。軟件簡(jiǎn)介AI算法部署旨在將抽象描述的多框架算法
    的頭像 發(fā)表于 06-06 17:04 ?1139次閱讀
    RISC-V架構(gòu)下AI融合算力及其軟件<b class='flag-5'>棧</b>實(shí)踐

    基于APM32F407如何制作I2C EEPROM(AT24C02型號(hào))的MDK-Keil下載算法

    基于APM32F407如何制作I2C EEPROM(AT24C02型號(hào))的Keil下載算法,這樣在我們下載代碼時(shí)可以一鍵把數(shù)據(jù)燒錄到EEPROM中。
    的頭像 發(fā)表于 04-11 11:06 ?1751次閱讀
    基于APM32F407如何制作I2C EEPROM(AT24C<b class='flag-5'>02</b>型號(hào))的MDK-Keil下載<b class='flag-5'>算法</b>

    深入淺出解析低功耗藍(lán)牙協(xié)議

    Bluetooth LE協(xié)議為什么要分層?怎么理解Bluetooth LE“連接”?如果Bluetooth LE協(xié)議只有ATT層沒有GATT層會(huì)發(fā)生什么? 一、協(xié)議框架 一般而言,我們把某個(gè)
    的頭像 發(fā)表于 04-09 14:49 ?987次閱讀
    深入淺出解析低功耗藍(lán)牙協(xié)議<b class='flag-5'>棧</b>

    74VHC02;74VHCT02四路2輸入或非門規(guī)格書

    電子發(fā)燒友網(wǎng)站提供《74VHC02;74VHCT02四路2輸入或非門規(guī)格書.pdf》資料免費(fèi)下載
    發(fā)表于 02-11 16:10 ?0次下載
    74VHC<b class='flag-5'>02</b>;74VHCT<b class='flag-5'>02</b>四路2輸入或非門規(guī)格書

    自動(dòng)駕駛?cè)?b class='flag-5'>棧自研可行嗎?

    隨著自動(dòng)駕駛加速落地,全自研模式在高階智能駕駛技術(shù)領(lǐng)域逐漸成為共識(shí),這種模式指的是整車廠從底層硬件、軟件算法到系統(tǒng)集成全面自主開發(fā),而非依賴于第三方供應(yīng)商或Tier 0.5模式(車企與供應(yīng)商
    的頭像 發(fā)表于 01-27 10:24 ?3375次閱讀

    MODBUS串口通訊初級(jí)入門手冊(cè)

    初級(jí)入門手冊(cè)介紹
    發(fā)表于 01-23 16:24 ?4次下載

    曙光云開啟全智能時(shí)代

    近日,“全可信 云中生智”曙光云戰(zhàn)略發(fā)布會(huì)召開。曙光云從首創(chuàng)“城市云”進(jìn)化到實(shí)現(xiàn)“全智能云”,打造“云智、云安、云算、云數(shù)”四位一體能力體系,深度賦能千行百業(yè)數(shù)智化轉(zhuǎn)型升級(jí)。
    的頭像 發(fā)表于 12-19 15:11 ?899次閱讀

    常見的lvs負(fù)載均衡算法

    常見的lvs負(fù)載均衡算法包括輪詢(RR)、加權(quán)輪詢(WRR)、最小連接(LC)、加權(quán)最小連接(WLC)、基于局部性的最少鏈接(LBLC)、帶復(fù)制的LBLC(LBLCR)、目標(biāo)地址散列(DH)、源地址
    的頭像 發(fā)表于 12-12 13:50 ?923次閱讀