8 包含min函數的棧

0 引言

題目:定義棧的數據結構,請在該類型中實現一個能夠得到棧的最小元素的min函數。在該棧中,調用min、push及pop的時間復雜度都是O(1).

1 抽象問題具體化

2 具體問題抽象分析

需要解決的兩個主要問題如下。

(1)如何在復雜度O(1)的條件下,返回當前棧的最小值。解決思路是定義一個minNum變量保存當前棧的最小值。

(2)另外一個問題是如果當前最小值被彈出了,如何更新minNum的值。解決思路是定義一個新的棧,該棧用于保存次小的值。涉及到兩步操作:

1)什么時候入棧:當前入棧的值小于等于最小值時,入棧

2)什么時候出棧:當前出棧值等于最小值時,更新最小值,出棧

3 demo

 
    stack<int> myStack;  // 數據棧stack<int> minorMinNum;   // 輔助棧int minNum = 99999999;     // 最小值void push(int value) {if(value <= minNum){     // 只有滿足當前入棧值小于等于最小值的條件,才將該值壓入輔助棧中,同時更新最小值
            minorMinNum.push(value);minNum = value;            }           myStack.push(value);}void pop() {int temp;if(!myStack.empty()){temp = myStack.top();myStack.pop();}            if(!minorMinNum.empty()){            if(temp == minNum){                // 只有滿足當前出棧值等于最小值的條件,更新最小值,同時輔助棧出棧
                minorMinNum.pop();minNum = minorMinNum.top();                }                }}int top() {return myStack.top();}int min() {return minNum;}
 

4 代碼優化

可以將上述變量minNum給省掉,寫法精簡如下。

?

    stack<int> myStack;stack<int> minorMinNum;void push(int value) {if(minorMinNum.empty()){minorMinNum.push(value);}else if(value <= minorMinNum.top())minorMinNum.push(value);                  myStack.push(value);}void pop() {      if(!myStack.empty() && !minorMinNum.empty()){if(myStack.top() == minorMinNum.top())minorMinNum.pop();myStack.pop();}}int top() {return myStack.top();}int min() {return minorMinNum.top();}

?

轉載于:https://www.cnblogs.com/ghjnwk/p/10020287.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/395927.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/395927.shtml
英文地址,請注明出處:http://en.pswp.cn/news/395927.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《Adobe Illustrator大師班:經典作品與完美技巧賞析》—Svetlana Makarova

本節書摘來自異步社區《Adobe Illustrator大師班&#xff1a;經典作品與完美技巧賞析》一書中的Svetlana Makarova&#xff0c;作者【英】Sharon Milne,更多章節內容可以訪問云棲社區“異步社區”公眾號查看。 Svetlana MakarovaAdobe Illustrator大師班&#xff1a;經典作品與…

navicat無法連接遠程mysql數據庫_navicat無法遠程連接mysql的解決方法

近日在Ubuntu上安裝了一個 MySQL 5.0&#xff0c;因為使用 phpMyAdmin 還必須安裝 PHP&#xff0c;所以打算直接使用遠程管理工具Navicat for MySQL 來連接。在 Ubuntu 中通過 mysql 命令行創建好一個數據表并分配了權限&#xff1a;代碼如下:GRANT ALL ON testdb.* TO usera I…

有關軟件測試的證書,軟件測試證書有用嗎

要想知道證書有什么用&#xff0c;我們就要詳細了解軟件評測師考試&#xff0c;以及拿到證書的價值。那么下面和小編來看看這篇軟件測試證書有用嗎&#xff0c;一定會有收獲。一、證書考試軟件評測師考試是全國計算機技術與軟件技術資格考試的一個中級考試。考試不規定學歷和資…

計算機科學導論第五版_五月份將開始提供438項免費在線編程和計算機科學課程

計算機科學導論第五版Five years ago, universities like MIT and Stanford first opened up free online courses to the public. Today, more than 700 schools around the world have created thousands of free online courses.五年前&#xff0c;麻省理工學院和斯坦福大學…

python D29 socketserver以及FTB

一、socketserver 基于tcp協議下的socket只能和一個客戶端通信&#xff0c;如果用socketserver可以實現和多個客戶端通信。 他是在socket的基礎上進行封裝&#xff0c;也就是說底層還是調用的socket&#xff0c;在py2.7里面叫做SocketServer也就是大寫了兩個S&#xff0c;在py3…

計算機節電模式不能打開,電腦進入節電模式打不開怎么辦

大家好&#xff0c;我是時間財富網智能客服時間君&#xff0c;上述問題將由我為大家進行解答。電腦進入節電模式打不開的原因及解決方法如下&#xff1a;1、顯示器和顯卡接觸不良解決辦法&#xff1a;檢查顯示器和顯卡的連接是否正確&#xff0c;接觸是否良好&#xff1b;2、顯…

sphinx mysql存儲引擎_基于Sphinx+MySQL的千萬級數據全文檢索(搜索引擎)架構設計...

Sphinx&#xff0c;單一索引最大可包含1億條記錄&#xff0c;在1千萬條記錄情況下的查詢速度為0.x秒(毫秒級)。Sphinx創建索引的速度為&#xff1a;創建100萬條記錄的索引只需3&#xff5e;4分鐘&#xff0c;創建1000萬條記錄的索引可以在50分鐘內完成&#xff0c;而只包含最新…

《第一桶金怎么賺——淘寶開店創業致富一冊通》一一1.1 創業者需具備的素質...

本節書摘來自異步社區出版社《第一桶金怎么賺——淘寶開店創業致富一冊通》一書中的第1章&#xff0c;第1.1節&#xff0c;作者&#xff1a;葛存山&#xff0c;更多章節內容可以訪問云棲社區“異步社區”公眾號查看。 1.1 創業者需具備的素質 第一桶金怎么賺——淘寶開店創業致…

4-1 線程安全性-原子性-atomic-1

轉載于:https://www.cnblogs.com/ZHONGZHENHUA/p/10026627.html

構建了我的第一個React Native應用程序之后,我現在確信這是未來。

by Taylor Milliman泰勒米利曼(Taylor Milliman) 構建了我的第一個React Native應用程序之后&#xff0c;我現在確信這是未來。 (After building my first React Native app, I’m now convinced it’s the future.) After a few weeks of playing around with React Native, …

delphi7 提示注冊過期問題

很同情你得經過~ 因為我以前也是經常遇見這個問題~就和你說得一樣~ 后來~ 我發現 下載使用的Delphi 7只能使用一個注冊碼&#xff0c;那就是:6AMD-PKG68E-DB8PP7-9SFE 3QH-9QW所以,你先把C:\Documents and Settings\Administrator\.borland文件夾下的兩個文件刪除然后用 Progra…

計算機開機引導的結果是,電腦開機顯示引導媒體是怎么回事

電腦開機顯示引導媒體是怎么回事分類&#xff1a;數據恢復常見問題|最后更新&#xff1a;2020年4月9日開機顯示重新啟動并選擇適當的引導設備或插入1.如果主機上接有可移動存儲介質(如光盤、移動硬盤、U盤等),將其拔掉,然后重啟。2.如果仍然這樣,進入主板設置中,依次檢測以下幾…

《操作系統真象還原》——0.23 操作系統是如何識別文件系統的

本節書摘來自異步社區《操作系統真象還原》一書中的第0章&#xff0c;第0.23節&#xff0c;作者&#xff1a;鄭鋼著&#xff0c;更多章節內容可以訪問云棲社區“異步社區”公眾號查看 0.23 操作系統是如何識別文件系統的 我們知道&#xff0c;一個硬盤上可以有很多分區&#xf…

mysql怎樣修改my ini_mysql修改my.ini報錯怎么辦

mysql修改my.ini報錯的解決辦法&#xff1a;首先將mysql默認編碼改成utf8mb4&#xff0c;并修改【my.ini】配置&#xff1b;然后修改變量&#xff0c;并檢查是否設置成功即可。更多相關免費學習推薦&#xff1a;mysql教程(視頻)mysql修改my.ini報錯的解決辦法&#xff1a;將mys…

golang---map類型

map 類似其它語言中的哈希表或字典&#xff0c;以key-value形式存儲數據key必須是支持或!比較運算的類型&#xff0c;不可以是函數、map或sliceMap查找比線性搜索快很多&#xff0c;但比使用索引訪問數據的類型慢100倍 Map使用make()創建&#xff0c;支持:這種簡寫方式 make([k…

易語言程序應用程序錯誤退出_為什么我退出Google并構建了一個向孩子們教授個人理財的應用程序

易語言程序應用程序錯誤退出Many of my friends thought I was crazy to leave a great position at Google to help parents and kids learn about money. Maybe they’re right.我的許多朋友都認為我為在谷歌上任職以幫助父母和孩子了解金錢而感到瘋狂。 也許他們是對的。 B…

藍疊 正在檢查服務器最新,Windows update一直停留在正在檢查更新

Windows update一直停留在正在檢查更新&#xff0c;為什么啊&#xff1f;一、查看相關服務是否開始&#xff1a;請您根據以下步驟&#xff0c;確認windows update & BITS服務設置1. 按下WinR鍵輸入“services.msc”(輸入時不要打引號)&#xff0c;并按下回車。如果此時彈出…

spring-DataSource

spring支持的dataSource有好多&#xff0c; 如&#xff1a;自帶的org.springframework.jdbc.datasource.DriverManagerDataSource ibatis、c3p0、JDBC、hibernate等等&#xff1b; 首先看第一種&#xff0c;使用自帶的datasource&#xff1a; 1、項目結構 提示&#xff1a;spri…

《Nmap滲透測試指南》—第7章7.8節后臺打印機服務漏洞

本節書摘來自異步社區《Nmap滲透測試指南》一書中的第7章7.8節后臺打印機服務漏洞&#xff0c;作者 商廣明,更多章節內容可以訪問云棲社區“異步社區”公眾號查看。 7.8 后臺打印機服務漏洞表7.8所示為本章節所需Nmap命令表&#xff0c;表中加粗命令為本小節所需命令——后臺打…

VSCODE 配置遠程調試環境

以下內容為本人的著作&#xff0c;如需要轉載&#xff0c;請聲明原文鏈接 微信公眾號「englyf」https://mp.weixin.qq.com/s/f1KZOlL92ojes-r2l9rlCw 我的需求是&#xff0c;在Windows桌面環境下&#xff0c;通過 VSCODE 遠程調試在服務器(或者其它遠程主機)的工程代碼。其實就…