亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

六、隊列的實現

發布時間:2020-07-17 13:56:16 來源:網絡 閱讀:244 作者:少年不在了 欄目:編程語言

隊列的定義及實現

?隊列的定義
??隊列是一種特殊的線性表
??隊列僅在線性表的兩端進行操作
???隊頭(Front):取出數據元素的一端
???隊尾(Rear):插入數據元素的一端
?隊列的性質
??先進先出(FIFO,First In First Out)
六、隊列的實現
?隊列的一些常用操作
??創建隊列
??銷毀隊列
??清空隊列
??進隊列
??出隊列
??獲取隊頭元素
??獲取隊列的長度
?隊列的順序存儲實現
六、隊列的實現
實現代碼:附件中SeqQue文件夾
?隊列的鏈式存儲實現
六、隊列的實現
實現代碼:附件中ListQue文件夾

隊列的優化實現

?順序隊列
??線性表的第一個元素作為隊頭
??線性表的最后一個元素作為隊尾
?入隊的新元素是在線性表的最后,時間復雜度為O(1)
?出隊時需要將后續的所有元素向前移動,時間復雜度O(n)
問題:如何將出隊操作的時間復雜度降低到O(1)?
順序隊列的優化方案
?定義front使其始終代表隊頭的下標
??出隊時將隊頭元素返回,且front++
?定義rear使其始終代表隊尾下一個元素的下標
??入隊時將新元素插入,且rear++
?沒有必要只將下標為0的位置定義為隊頭
六、隊列的實現
順序隊列的關鍵狀態
?初始狀態:length == 0, front == 0, rear == 0;
?空隊列狀態:length == 0, front == rear;
?滿隊列狀態:length == capacity, front == rear;
循環使用隊列中的空間
?入隊:rear = (rear + 1) % capacity;
?出隊:front = (front + 1) % capacity;
實現代碼:附件中SeqQue_2文件夾
鏈式隊列的瓶頸
?鏈式隊列
??線性表的第一個元素作為隊頭
??線性表的最后一個元素作為隊尾
?入隊的新元素是在線性表的最后,時間復雜度為O(n)
?出隊的元素即鏈表的第一個元素,時間復雜度O(1)
問題:如何將入隊操作的時間復雜度降低到O(1)?
鏈式隊列的優化方案
?定義rear指針始終指向鏈表中的最有一個元素
??入隊時將新元素通過rear插入隊尾,且將rear指向新元素
六、隊列的實現
鏈式隊列的關鍵狀態
?空隊列狀態:front == NULL, rear == NULL;
關鍵操作
?入隊:
??rear->next = node;
??rear = node;
??node->next = NULL;
?出隊:
??front = front->next;
實現代碼:附件中ListQue_2文件夾

隊列的特別實現

棧與隊列:用棧實現隊列
六、隊列的實現
實現思路
?準備兩個棧用于實現隊列:inStack和outStack
?當有新元素入隊時:將其壓入inStack中
?當需要出隊時:
??當outStack為空時:
???1. 將inStack中的元素逐一彈出并壓入outStack中
???2. 將outStack的棧頂元素彈出
??當outStack不為空時:
???– 直接將outStack的棧頂元素彈出
算法框架
六、隊列的實現
實現代碼:附件中NewQue文件夾

附件

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阳江市| 边坝县| 郸城县| 策勒县| 乌拉特前旗| 巴彦淖尔市| 开远市| 桂阳县| 芮城县| 陇川县| 河津市| 武宣县| 静海县| 突泉县| 万载县| 衡阳市| 自治县| 新宁县| 麦盖提县| 厦门市| 青田县| 全南县| 防城港市| 罗田县| 铜山县| 阿拉善盟| 和龙市| 淮南市| 包头市| 沿河| 纳雍县| 石城县| 梅河口市| 浪卡子县| 南安市| 泾川县| 樟树市| 县级市| 宁国市| 琼结县| 读书|