選單
×
   ❮     
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++ 集合


C++ 集合 (Set)

Set 儲存唯一元素,這些元素

  • 會自動按升序排序。
  • 是唯一的,這意味著相等或重複的值將被忽略。
  • 可以新增或刪除,但現有元素的值不能被更改。
  • 不能透過索引號訪問,因為順序是基於排序而非索引的。

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

// 包含 set 庫
#include <set>

建立集合

要建立 set,請使用 set 關鍵字,並在尖括號 <> 中指定它應該儲存的**型別**,然後是 set 的名稱,例如:set<type> setName

示例

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

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

示例

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

// 列印 set 元素
for (string car : cars) {
  cout << car << "\n";
}

輸出將是:

寶馬
福特
Mazda
沃爾沃
自己動手試一試 »

從上面的結果可以看出,set 中的元素會自動排序。在這種情況下,因為我們處理的是字串,所以是按字母順序排序的。

如果您將整數儲存在 set 中,返回的值將按數字順序排序

示例

// 建立一個名為 numbers 的 set,它將儲存整數
set<int> numbers = {1, 7, 3, 2, 5, 9};

// 列印 set 元素
for (int num : numbers) {
  cout << num << "\n";
}

輸出將是:

1
2
3
5
7
9
自己動手試一試 »

注意: set 的型別(例如上面示例中的 stringint)一旦宣告就無法更改。


按降序對 Set 進行排序

預設情況下,set 中的元素按升序排序。如果要反轉順序,可以使用尖括號內的 greater<type> 仿函式,如下所示

示例

// 按降序對 set 中的元素進行排序
set<int, greater<int>> numbers = {1, 7, 3, 2, 5, 9};
// 列印元素
for (int num : numbers) {
  cout << num << "\n";
}

輸出將是:

9
7
5
3
2
1
自己動手試一試 »

注意: greater<type> 中指定的型別必須與 set 中元素的型別(我們示例中的 int)相匹配。



唯一元素

Set 中的元素是唯一的,這意味著它們不能重複或相等。

例如,如果我們嘗試兩次將 "BMW" 新增到 set 中,重複的元素將被忽略

示例

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

// 列印 set 元素
for (string car : cars) {
  cout << car << "\n";
}

輸出將是:

寶馬
福特
Mazda
沃爾沃
自己動手試一試 »

新增元素

要向 set 新增元素,您可以使用 .insert() 函式

示例

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

// 新增新元素
cars.insert("Tesla");
cars.insert("VW");
cars.insert("Toyota");
cars.insert("Audi");
自己動手試一試 »

移除元素

要從 set 中刪除特定元素,您可以使用 .erase() 函式

示例

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

// 刪除元素
cars.erase("Volvo");
cars.erase("Mazda");
自己動手試一試 »

要刪除 set 中的所有元素,您可以使用 .clear() 函式

示例

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

// 刪除所有元素
cars.clear();
自己動手試一試 »

查詢 Set 的大小

要查詢 set 中有多少個元素,請使用 .size() 函式

示例

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

檢查 Set 是否為空

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

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

示例

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

示例

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

遍歷 Set

您可以使用 **for-each 迴圈**來遍歷 set

示例

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

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

提示: 也可以使用 迭代器 遍歷 set,您將在後面的章節中瞭解更多。



×

聯絡銷售

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

報告錯誤

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

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

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