選單
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP How to W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

C++ 教程

C++ 主頁 C++ 簡介 C++ 入門 C++ 語法 C++ 輸出 C++ 註釋 C++ 變數 C++ 使用者輸入 C++ 資料型別 C++ 運算子 C++ 字串 C++ 數學 C++ 布林值 C++ If...Else C++ Switch C++ While 迴圈 C++ For 迴圈 C++ Break/Continue C++ 陣列 C++ 結構體 C++ 列舉 C++ 引用 C++ 指標

C++ 函式

C++ 函式 C++ 函式引數 C++ 函式過載 C++ 作用域 C++ 遞迴

C++ 類

C++ OOP C++ 類/物件 C++ 類方法 C++ 建構函式 C++ 訪問修飾符 C++ 封裝 C++ 繼承 C++ 多型 C++ 檔案 C++ 異常 C++ 日期

C++ 資料結構

C++ 資料結構與 STL C++ Vectors C++ List C++ Stacks C++ Queues C++ Deque C++ Sets C++ Maps C++ 迭代器 C++ 演算法

C++ How To

C++ 兩數相加 C++ 隨機數

C++ 參考

C++ 參考 C++ 關鍵字 C++ <iostream> C++ <fstream> C++ <cmath> C++ <string> C++ <cstring> C++ <ctime> C++ <vector> C++ <algorithm>

C++ 示例

C++ 示例 C++ 現實生活中的例子 C++ 編譯器 C++ 練習 C++ 測驗 C++ 證書


C++ Deque


C++ Deque

在上一頁中,您學習了 佇列 中的元素是在末尾新增,在開頭移除。

而 deque(代表 double-ended queue,雙端佇列)則更靈活,因為元素可以從兩端(開頭和末尾)新增和移除。您也可以透過索引號訪問元素。

要使用 deque,您必須包含 <deque> 標頭檔案

// 包含 deque 庫
#include <deque>

建立 Deque

要建立一個 deque,請使用 deque 關鍵字,並在尖括號 <> 中指定它要儲存的值的型別,然後是 deque 的名稱,例如: deque<type> dequeName

示例

// 建立一個名為 cars 的 deque,它將儲存字串
deque<string> cars;

如果您想在宣告時就新增元素,請將它們放在花括號 {} 中,用逗號分隔的列表中

示例

// 建立一個名為 cars 的 deque,它將儲存字串
deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 列印 deque 元素
for (string car : cars) {
  cout << car << "\n";
}
自己動手試一試 »

注意: Deque 的型別(在我們的示例中為 string)在聲明後不能更改。


訪問 Deque

您可以透過方括號 [] 中的索引號來訪問 deque 元素。

Deque 是從 0 開始索引的,這意味著 [0] 是第一個元素,[1] 是第二個元素,以此類推。

示例

// 建立一個名為 cars 的 deque,它將儲存字串
deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 獲取第一個元素
cout << cars[0];  // 輸出 Volvo

// 獲取第二個元素
cout << cars[1];  // 輸出 BMW
自己動手試一試 »

您還可以使用 .front().back() 函式來訪問 deque 的第一個或最後一個元素

示例

// 建立一個名為 cars 的 deque,它將儲存字串
deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 獲取第一個元素
cout << cars.front();

// 獲取最後一個元素
cout << cars.back();
自己動手試一試 »

要訪問指定索引處的元素,可以使用 .at() 函式並指定索引號

示例

// 建立一個名為 cars 的 deque,它將儲存字串
deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 獲取第二個元素
cout << cars.at(1);

// 獲取第三個元素
cout << cars.at(2);
自己動手試一試 »

注意: .at() 函式通常比方括號 [] 更受青睞,因為它會在元素超出範圍時丟擲錯誤訊息。

示例

// 建立一個名為 cars 的 deque,它將儲存字串
deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 嘗試訪問一個不存在的元素(將丟擲異常)
cout << cars.at(6);
自己動手試一試 »


修改 Deque 元素

要更改特定元素的值,可以引用索引號

示例

deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 更改第一個元素的值
cars[0] = "Opel";

cout << cars[0];  // 現在輸出 Opel 而不是 Volvo
自己動手試一試 »

但是,使用 .at() 函式更安全

示例

deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 更改第一個元素的值
cars.at(0) = "Opel";

cout << cars.at(0);  // 現在輸出 Opel 而不是 Volvo
自己動手試一試 »

新增 Deque 元素

要向 deque 新增元素,您可以使用 .push_front() 在 deque 的開頭插入元素,並使用 .push_back() 在末尾新增元素。

示例

deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 在開頭新增一個元素
cars.push_front("Tesla");

// 在末尾新增一個元素
cars.push_back("VW");
自己動手試一試 »

移除 Deque 元素

要從 deque 中移除元素,請使用 .pop_front() 從 deque 的開頭移除元素,並使用 .pop_back() 在末尾移除元素。

示例

deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 移除第一個元素
cars.pop_front();

// 移除最後一個元素
cars.pop_back();
自己動手試一試 »

Deque 大小

要找出 deque 中有多少個元素,請使用 .size() 函式

示例

deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
cout << cars.size();  // 輸出 4
自己動手試一試 »

檢查 Deque 是否為空

使用 .empty() 函式來判斷 deque 是否為空。

.empty() 函式在 deque 為空時返回 1true),否則返回 0false)。

示例

deque<string> cars;
cout << cars.empty();  // 輸出 1 (Deque 為空)
自己動手試一試 »

示例

deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
cout << cars.empty();  // 輸出 0 (非空)
自己動手試一試 »

遍歷 Deque

您可以使用 for 迴圈結合 .size() 函式來遍歷 deque 元素。

示例

deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

for (int i = 0; i < cars.size(); i++) {
  cout << cars[i] << "\n";
}
自己動手試一試 »

您也可以使用基於範圍的 for 迴圈(在 C++ 11 (2011) 版本中引入),這種方式更簡潔,可讀性也更好。

示例

deque<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

for (string car : cars) {
  cout << car << "\n";
}
自己動手試一試 »

提示: 也可以使用 迭代器 來遍歷 deque,這將在後面的章節中詳細介紹。



×

聯絡銷售

如果您想將 W3Schools 服務用於教育機構、團隊或企業,請傳送電子郵件給我們
sales@w3schools.com

報告錯誤

如果您想報告錯誤,或想提出建議,請傳送電子郵件給我們
help@w3schools.com

W3Schools 經過最佳化,旨在方便學習和培訓。示例可能經過簡化,以提高閱讀和學習體驗。教程、參考資料和示例會不斷審查,以避免錯誤,但我們無法保證所有內容的完全正確性。使用 W3Schools 即表示您已閱讀並接受我們的使用條款Cookie 和隱私政策

版權所有 1999-2024 Refsnes Data。保留所有權利。W3Schools 由 W3.CSS 提供支援