網(wǎng)站首頁 編程語言 正文
1.棧的介紹
棧的實現(xiàn)方式分為3種
- 基于靜態(tài)數(shù)組實現(xiàn),內(nèi)部預(yù)設(shè)一個很大的數(shù)組對象, 實現(xiàn)簡單,缺點是空間受限。
- 基于動態(tài)數(shù)組實現(xiàn),內(nèi)部預(yù)設(shè)一個容量值,然后分配一段內(nèi)存空間數(shù)組,如果入棧大于默認(rèn)容量值時,則再次擴(kuò)大分配新的內(nèi)存數(shù)組,并將舊數(shù)組拷貝至新數(shù)組及釋放舊數(shù)組.
- 基于雙向循環(huán)鏈表實現(xiàn)
棧的函數(shù)需要實現(xiàn)如下所示:
-
T pop() :?
出棧并返回棧頂元素 -
void??push(const T &t) :
?入棧? -
const T & top() const :
?獲取const類型棧頂元素 -
T &top() :?
獲取棧頂元素 -
int length() const:?
獲取數(shù)量(父類已經(jīng)實現(xiàn))void clear():?清空棧(父類已經(jīng)實現(xiàn))
本章,我們實現(xiàn)的?;趧討B(tài)數(shù)組實現(xiàn),它的父類是我們之前實現(xiàn)的Vector類:
C++?動態(tài)數(shù)組模版類Vector實例詳解
所以代碼實現(xiàn)會非常簡單.
2.棧實現(xiàn)
代碼如下所示:
#ifndef Stack_H #define Stack_H #include "throw.h" // throw.h里面定義了一個ThrowException拋異常的宏,如下所示: //#include//using namespace std; //#define ThrowException(errMsg) {cout<<__FILE__<<" LINE"<<__LINE__<<": "< class Stack : public Vector { public: T pop() { if(Vector ::isEmpty()) { // 如果棧為空,則拋異常 ThrowException("Stack is empty ..."); } T t = Vector ::data()[Vector ::length() - 1]; Vector ::resize(Vector ::length() - 1); return t; } // 入棧,實際就是append尾部添加成員 void push(const T &t) { Vector ::append(t); } T &top() { if(Vector ::isEmpty()) { ThrowException("Stack is empty ..."); } return Vector ::data()[Vector ::length() - 1]; } const T &top() const { if(Vector ::isEmpty()) { ThrowException("Stack is empty ..."); } return Vector ::data()[Vector ::length() - 1]; } }; #endif // Stack_H
3.代碼測試
int main(int argc, char *argv[]) { Stackstack; cout<<"******* current length:"<
運行打印:
總結(jié)
原文鏈接:https://blog.csdn.net/qq_37997682/article/details/123123143
相關(guān)推薦
- 2022-09-24 pandas刪除某行或某列數(shù)據(jù)的實現(xiàn)示例_python
- 2023-07-22 spark啟動參數(shù)性能優(yōu)化
- 2022-08-29 Python如何利用pandas讀取csv數(shù)據(jù)并繪圖_python
- 2022-04-21 Python的基礎(chǔ)語法和輸入輸出函數(shù)你都了解嗎_python
- 2022-04-05 expected a string (for built-in components) or a c
- 2022-03-28 Python?pandas之多級索引取值詳解_python
- 2022-11-06 Python?munch包?/Munch()?的用法詳解_python
- 2022-10-17 Django?logging日志模塊實例詳解(日志記錄模板配置)_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支