最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(wǎng) 會(huì)員登陸 & 注冊(cè)

【數(shù)據(jù)結(jié)構(gòu)】數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn) 1.2:數(shù)組棧(C++版)

2023-03-04 20:00 作者:九霄星河  | 我要投稿

數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn) 1.2:數(shù)組棧(C++版)

  • 1. 概念及基本框架

  • 2. 基本操作程序?qū)崿F(xiàn)

    • 2.1 入棧操作

    • 2.2 出棧操作

    • 2.3 查找操作

    • 2.4 其他操作

  • 3. 算法復(fù)雜度分析

    • 3.1 入棧操作

    • 3.2 出棧操作

    • 3.3 查找操作

  • 4. 完整代碼

1. 概念及基本框架

?可以看做一種特殊的?數(shù)組?,所以我使用第一節(jié)實(shí)現(xiàn)的?動(dòng)態(tài)數(shù)組?來實(shí)現(xiàn)棧這種數(shù)據(jù)結(jié)構(gòu)。當(dāng)然,棧也可以通過其他方式來實(shí)現(xiàn)。因?yàn)樵摋J峭ㄟ^動(dòng)態(tài)數(shù)組實(shí)現(xiàn)的,所以稱之為?數(shù)組棧?。

棧的結(jié)構(gòu)

棧的結(jié)構(gòu)如上圖所示,可知棧的基本特性如下:
1.?有?棧頂?和?棧底?兩端。
2.入棧?和?出棧?操作只能從?棧頂?進(jìn)行。
3.后?入棧?的先?出棧?,即?后進(jìn)先出(Last In First Out),LIFO?。
還有一個(gè)隱含特性,棧可以自行?擴(kuò)容(縮容),而不需要用戶關(guān)心,很顯然,動(dòng)態(tài)數(shù)組已經(jīng)滿足了這個(gè)要求。
由此可見,棧的操作并不多,我使用了一個(gè)由?純虛函數(shù)?構(gòu)成的?抽象類?作為一個(gè)接口來定義這些操作。具體代碼如下:

下面只需要通過繼承?抽象類,并且重寫?純虛函數(shù)?,就可以完成?數(shù)組棧?的實(shí)現(xiàn)。數(shù)組棧類的框架如下:

這個(gè)類內(nèi)部定義一個(gè)動(dòng)態(tài)數(shù)組類對(duì)象,為了保護(hù)數(shù)據(jù),把它放在?private?部分,構(gòu)造函數(shù)?ArrayStack?底層調(diào)用的就是?Array?的構(gòu)造函數(shù)。用戶在構(gòu)造函數(shù)中也可以指定棧的大小。(默認(rèn)是10)為了兼容更多類型,這里使用了泛型的概念。

2. 基本操作程序?qū)崿F(xiàn)

2.1 入棧操作

入棧操作使用了動(dòng)態(tài)數(shù)組的增加最后一個(gè)元素的操作來實(shí)現(xiàn)。這里動(dòng)態(tài)數(shù)組內(nèi)部已經(jīng)提供了擴(kuò)容操作。

2.2 出棧操作

出棧操作使用了動(dòng)態(tài)數(shù)組的刪除最后一個(gè)元素的操作來實(shí)現(xiàn)。這里動(dòng)態(tài)數(shù)組內(nèi)部已經(jīng)提供了縮容操作。

2.3 查找操作

因?yàn)闂V荒塬@得棧頂元素,所以這里的查找操作也非常簡(jiǎn)單。

2.4 其他操作

3. 算法復(fù)雜度分析

3.1 入棧操作

入棧操作

最壞復(fù)雜度?O(1+n)?中第一個(gè)?1?是指元素移動(dòng)操作,第二個(gè)?n?是指動(dòng)態(tài)數(shù)組中的?resize?函數(shù),以下同理。
入??赡軙?huì)引發(fā)擴(kuò)容操作,平均而言,每增加?n?個(gè)元素,會(huì)擴(kuò)展一次,會(huì)發(fā)生?n?個(gè)元素的移動(dòng),所以平均下來是?O(1)?。

3.2 出棧操作

出棧操作

3.3 查找操作

查找操作

總體情況:

總體情況

由此可以看出,棧操作都是?O(1)?級(jí)別的時(shí)間復(fù)雜度。
注:這里并沒有改的操作,如果更改,需要先出棧,再入棧。

4. 完整代碼

動(dòng)態(tài)數(shù)組類?代碼:

抽象類?接口代碼:

數(shù)組棧?代碼:



【數(shù)據(jù)結(jié)構(gòu)】數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn) 1.2:數(shù)組棧(C++版)的評(píng)論 (共 條)

分享到微博請(qǐng)遵守國家法律
扎赉特旗| 广西| 图木舒克市| 泗阳县| 浮山县| 岳阳市| 鄯善县| 东丽区| 辽宁省| 通州区| 阳江市| 新龙县| 宁安市| 庆城县| 阳江市| 教育| 延边| 凉山| 永靖县| 左贡县| 万荣县| 建德市| 柳河县| 乡宁县| 南投市| 泸水县| 山丹县| 青神县| 上饶县| 临武县| 霍林郭勒市| 云梦县| 饶阳县| 八宿县| 修文县| 内乡县| 姚安县| 邵东县| 仲巴县| 胶州市| 中宁县|