棧和隊列--受限制的線性表

目錄

和隊列的定義和特點

1.1棧的定義和特點、

1.2隊列的定義和特點

1.3棧和隊列的應用

2.棧的表示和操作的實現

2.1棧的類型定義

2.2順序棧的表示和實現

2.2.1初始化

2.2.2入棧

2.2.3出棧

2.2.4取棧頂元素

2.3鏈棧的表示和實現

2.2.1初始化

2.2.2入棧

2.2.3出棧

2.2.4取棧頂元素

3.棧與遞歸(?????)

3.1采用遞歸算法解決的問題

3.2遞歸過程與遞歸棧

3.3遞歸算法的效率分析

3.4利用棧將遞歸算法轉化為非遞歸算法

4.隊列的表示和操作的實現

4.1隊列的類型定義

4.2循環隊列--隊列的順序表示和實現

4.3鏈隊--隊列的連時表示和實現

5.案例

6.小結(?)


和隊列的定義和特點

1.1棧的定義和特點、

:限定僅在表尾進行操作的線性表(LIFO/LIFO--先進后出,后進先出)

1.2隊列的定義和特點

隊列:限定僅在隊頭刪除,隊尾插入的線性表(FIFO/LILO -- 先進先出,后進后出)

1.3棧和隊列的應用

:1.數制的轉換;

原理:N=(N div d)*d +N mod d;

在計算過程中依次將余數壓入棧中,計算完畢,在依次彈出棧中的余數就是數制轉換的結果。

例題:405. 數字轉換為十六進制數 - 力扣(Leetcode)(建議自己試試也挺簡單,就不加代碼了)

2.括號匹配;

3.表達式求值

隊列:舞伴問題

這幾個其實也很簡單,(偷偷說)其實其中的而部分題目我更愿意用字符串來做。。。。

2.棧的表示和操作的實現

2.1棧的類型定義

棧的抽象數據類型定義:

ADT Stack{數據對象:D{ai | ai∈Elemset,i = 1,2,...,n,n≥0}數據關系:R = {<ai - 1,ai> | ai∈D,i = 2,...,n}約定an端為棧頂,a1端為棧底。基本操作:InitStack(&S)操作結果:構造一個空棧DestoyStack(&s)初始條件:棧S已經存在操作結果:棧S被銷毀ClearStack(&s)初始條件:棧S已經存在操作結果:棧S被清空為空棧StackEmpty(s)初始條件:棧S已經存在操作結果:若棧S為空棧,則返回true,否則返回falseGetTop(s)初始條件:棧S已經存在且非空操作結果:返回S的棧頂元素,不改變棧頂指針Push(&s,e)初始條件:棧S已經存在操作結果:插入元素為e的新的棧頂元素Pop(&s,&e)初始條件:棧S已經存在且非空操作結果:刪除S的棧頂元素,并用e返回其值StackTraverse(s)初始條件:棧S已經存在且非空操作結果:從棧頂到棧底依次對S的每個數據元素驚醒訪問}

2.2順序棧的表示和實現

2.2.1初始化

2.2.2入棧

2.2.3出棧

2.2.4取棧頂元素

2.3鏈棧的表示和實現

2.2.1初始化

2.2.2入棧

2.2.3出棧

2.2.4取棧頂元素

3.棧與遞歸(?????)

3.1采用遞歸算法解決的問題

3.2遞歸過程與遞歸棧

3.3遞歸算法的效率分析

3.4利用棧將遞歸算法轉化為非遞歸算法

4.隊列的表示和操作的實現

4.1隊列的類型定義

4.2循環隊列--隊列的順序表示和實現

4.3鏈隊--隊列的連時表示和實現

5.案例

6.小結(?

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

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

相關文章

Java-運算符和控制語句(下)(基于c語言的補充)

輸出到控制臺 System.out.println(msg); // 輸出一個字符串, 帶換行 System.out.print(msg); // 輸出一個字符串, 不帶換行 System.out.printf(format, msg); // 格式化輸出 從鍵盤輸入 使用 Scanner 讀取字符串/整數/浮點數 首先需要導入util包 自動導入util包 這里把回車看…

如何選擇最佳的文件傳輸協議?(FTP、TFTP、Raysync)

在數字化時代&#xff0c;通過互聯網傳輸文件是一項常見的任務。因此&#xff0c;選擇適合您企業需求的文件傳輸協議非常重要。 文件傳輸協議是發送方和接收方之間的一套規則和信息。它的作用就像網絡兩端都能理解的一種語言&#xff0c;使得數據可以正確輸出并帶有正確的文件…

【高頻面試題】JVM篇

文章目錄 一、JVM組成1.什么是程序計數器2.什么是Java堆&#xff1f;3.能不能介紹一下方法區(元空間&#xff09;4.你聽過直接內存嗎5.什么是虛擬機棧6.垃圾回收是否涉及棧內存&#xff1f;7.棧內存分配越大越好嗎&#xff1f;8.方法內的局部變量是否線程安全&#xff1f;9.什么…

NIO 非阻塞式IO

NIO Java NIO 基本介紹 Java NIO 全稱 Java non-blocking IO&#xff0c;是指 JDK 提供的新 API。從 JDK1.4 開始&#xff0c;Java 提供了一系列改進的輸入/輸出的新特性&#xff0c;被統稱為 NIO&#xff08;即 NewIO&#xff09;&#xff0c;是同步非阻塞的。NIO 相關類都被…

01-Spark環境部署

1 Spark的部署方式介紹 ? Spark部署模式分為Local模式&#xff08;本地模式&#xff09;和集群模式&#xff08;集群模式又分為Standalone模式、Yarn模式和Mesos模式&#xff09; 1.1 Local模式 Local模式常用于本地開發程序與測試&#xff0c;如在idea中 1.2 Standalone模…

PAT 1039 Course List for Student

個人學習記錄&#xff0c;代碼難免不盡人意。 Zhejiang University has 40000 students and provides 2500 courses. Now given the student name lists of all the courses, you are supposed to output the registered course list for each student who comes for a query. …

netty學習分享 二

操作系統IO模型與實現原理 阻塞IO 模型 應用程序調用一個IO函數&#xff0c;導致應用程序阻塞&#xff0c;等待數據準備好。如果數據沒有準備好&#xff0c;一直等待….數據準備好了&#xff0c;從內核拷貝到用戶空間,IO函數返回成功指示。 當調用recv()函數時&#xff0c;系…

釉面陶瓷器皿SOR/2016-175標準上架亞馬遜加拿大站

親愛的釉面陶瓷器皿和玻璃器皿制造商和賣家&#xff0c;亞馬遜加拿大站將執行SOR/2016-175法規。這是一份新的法規&#xff0c;規定了含有鉛和鎘的釉面陶瓷器和玻璃器皿需要滿足的要求。讓我們一起來看一看&#xff0c;為什么要實行SOR/2016-175法規&#xff1f;這是一個保護消…

yolo源碼注釋3——模型配置文件

代碼基于yolov5 v6.0 目錄&#xff1a; yolo源碼注釋1——文件結構yolo源碼注釋2——數據集配置文件yolo源碼注釋3——模型配置文件yolo源碼注釋4——yolo-py 模型配置文件一般放在 models 文件夾下的 XXX.yaml 文件中&#xff0c;以 yolov5s.yaml 為例&#xff1a; # YOLOv…

使用SpringAop切面編程通過Spel表達式實現Controller權限控制

目錄 參考一、概念SpEL表達式 二、開發引入包定義注解定義切面定義用戶上下文 三、測試新建Service在方法上注解新建Service在類上注解運行 參考 SpringBoot&#xff1a;SpEL讓復雜權限控制變得很簡單 一、概念 對于在Springboot中&#xff0c;利用自定義注解切面來實現接口…

opencv實戰項目 手勢識別-手勢音量控制(opencv)

本項目是使用了谷歌開源的框架mediapipe&#xff0c;里面有非常多的模型提供給我們使用&#xff0c;例如面部檢測&#xff0c;身體檢測&#xff0c;手部檢測等。 手勢識別系列文章 1.opencv實現手部追蹤&#xff08;定位手部關鍵點&#xff09; 2.opencv實戰項目 實現手勢跟蹤…

8月14日,每日信息差

1、FF正式交付首輛FF 91 2.0 Futurist Alliance給塔尖用戶 2、消息稱iPhone SE 4設計基于iPhone 14&#xff0c;但仍是后置單攝像頭 3、阿聯酋力推電動汽車發展。該政策將作為一個監管框架&#xff0c;明確電動汽車充電站等基礎設施建設的標準&#xff0c;并推動全國標準統一…

Jay17 2023.8.12日報

8.12 今天做了2題&#xff0c;CTFshow 紅包挑戰8&#xff08;PHP create_function()&#xff09;和BUU [RoarCTF 2019]Easy Java&#xff08;web.xml泄露&#xff09;。 此外一直在打NepCTF&#xff0c;出了一題&#xff08;ez_java_checkin&#xff09;簡單了解了java中shri…

Kafka消息隊列學習(一)

文章目錄 概述核心概念生產者示例同步 / 異步發送消息生產者參數配置ack-確認機制retries - 重試次數compression_type - 消息壓縮類型 分區機制分區策略 消費者消息有序性提交和偏移量偏移量提交方式手動提交 高可用設計 SpringBoot集成Kafka基本使用傳遞對象消息 概述 核心概…

HTTP之cookie基礎學習

目錄 Cookie 什么是Cookie Cookie分類 Cookie版本 Cookie工作原理 Cookie詳解 創建cookie cookie編碼 cookie過期時間選項 Cookie流程 Cookie使用 會話管理 個性化信息 記錄用戶的行為 Cookie屬性 domain選項 path選項 secure選項 cookie…

帶著問題學習分布式系統

寫在前面 聽過很多道理&#xff0c;卻依然過不好這一生。 看過很多關于學習的技巧、方法&#xff0c;卻沒應用到自己的學習中。 隨著年紀變大&#xff0c;記憶力越來越差&#xff0c;整塊的時間也越來越少&#xff0c;于是&#xff0c;越來越希望能夠更高效的學習。學習是一種習…

香港大學余濤組推出開源XLANG Agent!支持三種Agent模式

作者 |小戲、ZenMoore 一個新的未來又逐漸開始從理論走向現實走到我們身邊了。 語言的意義在于使用&#xff0c;而從 ChatGPT 以來這些大規模語言模型的意義&#xff0c;也必然絕不止于 Chat&#xff0c;在四個月前&#xff0c;我們介紹了清華大學關于工具學習的綜述《清華發布…

Python-OpenCV中的圖像處理-圖像特征

Python-OpenCV中的圖像處理-圖像特征 圖像特征Harris角點檢測亞像素級精度的角點檢測Shi-Tomasi角點檢測SIFT(Scale-Invariant Feature Transfrom)SURF(Speeded-Up Robust Features) 圖像特征 特征理解特征檢測特征描述 Harris角點檢測 cv2.cornerHarris(img, blockSize, ks…

海格里斯HEGERLS四向穿梭車倉儲解決方案在電子商務行業中的應用

隨著現代物流&#xff0c;尤其是智能化物流的飛速發展&#xff0c;河北沃克金屬制品有限公司看到了智能物流領域背后的巨大價值和市場空間&#xff0c;深知物流與供應鏈對企業發展的重要性。于是&#xff0c;引進了先進的高科技智能技術—HEGERLS四向穿梭車技術&#xff0c;并迅…

【日常積累】Linux下文件亂碼解決

linux下刪除亂碼文件、目錄 由于編碼原因&#xff0c;在linux服務器上上傳、創建中文文件或目錄時&#xff0c;會產生亂碼&#xff0c;如果想刪除它&#xff0c;有時候發現用rm命令是刪除不了的 這種情況下&#xff0c;用find命令可以刪除亂碼的文件或目錄。 首先進入亂碼文件…