亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++實(shí)現(xiàn)std::set的示例項(xiàng)目

 更新時(shí)間:2025年02月18日 10:14:24   作者:kucupung  
std::set是C++標(biāo)準(zhǔn)庫(kù)中的關(guān)聯(lián)容器,提供有序唯一元素集合,本文就來(lái)介紹一下std::set的具體使用,具有一定的參考價(jià)值,感興趣的可以了解一下

std::set 是 C++ 標(biāo)準(zhǔn)庫(kù)中的關(guān)聯(lián)容器,它提供了一種存儲(chǔ)唯一元素的有序集合。它提供了高效的插入、刪除和查找操作,并且能夠自動(dòng)維護(hù)元素的有序性和唯一性。

一、底層實(shí)現(xiàn)

std::set 的底層原理是基于紅黑樹(shù)(Red-Black Tree)。紅黑樹(shù)是一種自平衡的二叉搜索樹(shù),保證了樹(shù)的平衡性,從而保證了插入、刪除和查找操作的時(shí)間復(fù)雜度為 O(log n)。它滿(mǎn)足以下性質(zhì):

1、 每個(gè)節(jié)點(diǎn)要么是紅色,要么是黑色。
2、 根節(jié)點(diǎn)是黑色的。(插入的第一個(gè)元素)
3、 所有葉子節(jié)點(diǎn)(NIL 節(jié)點(diǎn))都是黑色的。
4、 如果一個(gè)節(jié)點(diǎn)是紅色的,則它的兩個(gè)子節(jié)點(diǎn)都是黑色的。
5、 對(duì)于每個(gè)節(jié)點(diǎn),從該節(jié)點(diǎn)到其后代葉子節(jié)點(diǎn)的簡(jiǎn)單路徑上,黑色節(jié)點(diǎn)的數(shù)量都相同。

在 std::set 中,每個(gè)元素都被 插入到紅黑樹(shù)中作為一個(gè)節(jié)點(diǎn)。當(dāng)插入一個(gè)新元素時(shí),std::set 會(huì)根據(jù)元素值的大小將其插入到合適的位置,同時(shí)保持紅黑樹(shù)的平衡性。在紅黑樹(shù)中查找元素時(shí),根據(jù)紅黑樹(shù)的特性,可以通過(guò)二分查找的方式高效地定位到目標(biāo)元素。
由于紅黑樹(shù)是一種高效的自平衡二叉搜索樹(shù),因此 std::set 能夠提供高效的插入、刪除和查找操作,同時(shí)保持元素的有序性和唯一性。

二、成員函數(shù)

std::set提供了一系列成員函數(shù)來(lái)操作集合。

  • insert: 向集合中插入元素。
  • emplace: 在集合中就地構(gòu)造元素。
  • erase: 從集合中刪除指定元素。
  • find: 查找集合中是否存在指定元素。
  • count: 返回集合中與指定元素相等的元素的數(shù)量(通常為0或1)。
  • clear: 清空集合中的所有元素。
  • size: 返回集合中元素的數(shù)量。
  • empty: 檢查集合是否為空。
  • swap: 交換兩個(gè)集合的內(nèi)容。
  • begin: 返回指向集合中第一個(gè)元素的迭代器。
  • end: 返回指向集合中最后一個(gè)元素之后位置的迭代器。
  • lower_bound: 返回指向第一個(gè)不小于給定鍵值的元素的迭代器。
  • upper_bound: 返回指向第一個(gè)大于給定鍵值的元素的迭代器。
  • equal_range: 返回一個(gè)范圍,其中包含所有與給定鍵值相等的元素。
  • max_size: 返回集合能容納的最大元素?cái)?shù)量。

Demo演示:

std::set<int> set1;
set1.insert(1);
set1.insert(2);
set1.insert(3);
set1.insert(4);
std::cout<<set1.size()<<std::endl; // 4
std::cout<<set1.empty()<<std::endl; // 0
std::cout<<*set1.find(2)<<std::endl; // 2
set1.erase(2);
std::cout<<(set1.find(2)==set1.end())<<std::endl; // 1
std::cout<<set1.count(3)<<std::endl; // 1
auto lower = set1.lower_bound(3);
auto upper = set1.upper_bound(3);
std::cout << "Lower bound of 3: " << *lower << std::endl; // Lower bound of 3: 3
std::cout << "Upper bound of 3: " << *upper << std::endl; // Upper bound of 4: 4
std::set<int> set2;
set2.swap(set1);
std::cout<<set1.size()<<" "<<set2.size()<<std::endl; // 0 3
std::cout<<set1.max_size()<<std::endl; // 230584300921369395
for (auto it = set2.begin(); it != set2.end(); ++it) {
    std::cout << *it << " "<<std::endl; // 1 3 4
}
auto range = set2.equal_range(3);
std::cout<<*range.first<<std::endl; // 3

三、自定義排序規(guī)則

std::set 默認(rèn)是根據(jù)元素的大小進(jìn)行排序的,采用的是嚴(yán)格弱序(Strict Weak Ordering)的比較方式。這意味著元素必須支持 < 運(yùn)算符,元素按照升序排列。

可以通過(guò)提供自定義的比較函數(shù)或者函數(shù)對(duì)象來(lái)實(shí)現(xiàn)排序規(guī)則。需要兩個(gè)步驟:
1、 定義比較函數(shù)或者函數(shù)對(duì)象
比較函數(shù):定義一個(gè)函數(shù),接受兩個(gè)參數(shù),比較它們的大小,并返回 true 或 false,表示它們的順序關(guān)系。
函數(shù)對(duì)象(Functor):定義一個(gè)類(lèi),重載 operator(),使得對(duì)象可以像函數(shù)一樣被調(diào)用,在其中實(shí)現(xiàn)比較邏輯。

2、 傳遞比較函數(shù)或者函數(shù)對(duì)象給 std::set 構(gòu)造函數(shù)
在創(chuàng)建 std::set 對(duì)象時(shí),通過(guò)傳遞比較函數(shù)或者函數(shù)對(duì)象作為第二個(gè)參數(shù),告訴集合如何比較元素的順序。

#include <iostream>
#include <set>

// 自定義比較函數(shù)
bool customCompare(int a, int b) {
    // 實(shí)現(xiàn)自定義的比較邏輯,這里以整數(shù)的絕對(duì)值大小為例
    return abs(a) < abs(b);
}

// 自定義函數(shù)對(duì)象(Functor)
struct CustomComparator {
    bool operator()(int a, int b) const {
        // 實(shí)現(xiàn)自定義的比較邏輯,這里以整數(shù)的平方大小為例
        return (a * a) < (b * b);
    }
};

int main() {
    // 使用自定義比較函數(shù)創(chuàng)建 std::set
    std::set<int, decltype(&customCompare)> customSet(customCompare);

    // 使用自定義函數(shù)對(duì)象創(chuàng)建 std::set
    std::set<int, CustomComparator> functorSet;

    // 插入元素
    customSet.insert(5);
    customSet.insert(-3);
    customSet.insert(2);

    functorSet.insert(5);
    functorSet.insert(-3);
    functorSet.insert(2);

    // 遍歷輸出結(jié)果
    std::cout << "Custom compare function set: ";
    for (int num : customSet) {
        std::cout << num << " ";
    }
    std::cout << std::endl;

    std::cout << "Functor set: ";
    for (int num : functorSet) {
        std::cout << num << " ";
    }
    std::cout << std::endl;

    return 0;
}

四、自定義對(duì)象排序

當(dāng) std::set 中存儲(chǔ)的元素是自定義對(duì)象時(shí),需要重載 < 運(yùn)算符,以便 std::set 能夠?qū)?duì)象進(jìn)行比較和排序。重載 < 運(yùn)算符的目的是定義對(duì)象之間的比較規(guī)則,以確定它們?cè)诩现械捻樞?。這樣,std::set 就可以使用這些規(guī)則來(lái)維護(hù)集合的有序性。
下面是一個(gè)示例,演示了如何定義一個(gè)自定義類(lèi)型的 Person 對(duì)象,并在 std::set 中使用自定義的比較函數(shù)進(jìn)行排序:

#include <iostream>
#include <set>
#include <string>

// 定義一個(gè)自定義的 Person 類(lèi)
class Person {
private:
    std::string name;
    int age;

public:
    Person(std::string name, int age) : name(name), age(age) {}

    // 重載 < 運(yùn)算符,用于自定義對(duì)象的比較規(guī)則
    bool operator<(const Person& other) const {
        // 按照年齡進(jìn)行比較
        return age < other.age;
    }

    // 為了便于輸出,重載 << 運(yùn)算符
    friend std::ostream& operator<<(std::ostream& os, const Person& person) {
        os << "Name: " << person.name << ", Age: " << person.age;
        return os;
    }
};

int main() {
    // 創(chuàng)建一個(gè)存儲(chǔ) Person 對(duì)象的 std::set 容器,并使用自定義的比較函數(shù)進(jìn)行排序
    std::set<Person> people;

    // 向集合中插入一些 Person 對(duì)象
    people.insert(Person("Alice", 30));
    people.insert(Person("Bob", 25));
    people.insert(Person("Charlie", 35));

    // 遍歷輸出集合中的元素,由于使用了自定義的比較規(guī)則,輸出時(shí)會(huì)按照年齡升序排列
    for (const auto& person : people) {
        std::cout << person << std::endl;
    }

    return 0;
}

在這個(gè)示例中,Person 類(lèi)具有 name 和 age 兩個(gè)屬性,我們通過(guò)重載 < 運(yùn)算符來(lái)定義了對(duì)象之間的比較規(guī)則,按照年齡進(jìn)行比較。然后,我們創(chuàng)建了一個(gè) std::set<Person> 容器,并向其中插入了幾個(gè) Person 對(duì)象。由于我們使用了自定義的比較函數(shù),因此在輸出容器中的元素時(shí),它們會(huì)按照年齡的升序排列。

五、性能問(wèn)題

std::set 在插入、刪除和查找等操作上具有穩(wěn)定且良好的性能特征,適用于需要高效管理有序唯一元素集合的場(chǎng)景。然而,在空間效率方面,它可能不如其他數(shù)據(jù)結(jié)構(gòu)(如 std::unordered_set)那么優(yōu)越。因此,在選擇數(shù)據(jù)結(jié)構(gòu)時(shí),需要根據(jù)具體的需求權(quán)衡其性能特征。

1、 插入和刪除操作的性能
插入和刪除操作的時(shí)間復(fù)雜度為 O(log n),其中 n 是集合中的元素?cái)?shù)量。這是因?yàn)榧t黑樹(shù)是一種自平衡的二叉搜索樹(shù),插入和刪除操作會(huì)導(dǎo)致樹(shù)的重新平衡,但是由于紅黑樹(shù)的特性,重新平衡的代價(jià)是受控的。
因此,std::set 在插入和刪除方面的性能比較穩(wěn)定,不受集合大小的影響。

2、 查找操作的性能
查找操作的時(shí)間復(fù)雜度也是 O(log n),因?yàn)榧t黑樹(shù)具有良好的平衡性,可以保證在平均情況下快速地查找元素。
std::set 提供了高效的查找功能,適用于需要快速檢索元素的場(chǎng)景。

3、 迭代器的性能
std::set 的迭代器是雙向迭代器,支持前向和后向遍歷,其性能與集合大小無(wú)關(guān),是常數(shù)時(shí)間復(fù)雜度的操作。
這意味著在遍歷 std::set 中的元素時(shí),無(wú)論集合大小如何,迭代器的操作都非常高效。

4、 內(nèi)存占用
std::set 使用紅黑樹(shù)作為底層數(shù)據(jù)結(jié)構(gòu),它是一種高效的平衡二叉搜索樹(shù),但是相對(duì)于其他數(shù)據(jù)結(jié)構(gòu)(如哈希表),它可能會(huì)占用更多的內(nèi)存。
紅黑樹(shù)需要維護(hù)額外的節(jié)點(diǎn)信息以保持平衡,因此在存儲(chǔ)相同數(shù)量的元素時(shí),std::set 可能會(huì)占用更多的內(nèi)存空間。

到此這篇關(guān)于C++實(shí)現(xiàn)std::set的示例項(xiàng)目的文章就介紹到這了,更多相關(guān)C++ std::set內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++中CSTRINGLIST用法詳解

    C++中CSTRINGLIST用法詳解

    這篇文章主要介紹了C++中CSTRINGLIST用法詳解的相關(guān)資料,需要的朋友可以參考下
    2015-06-06
  • C++中獲取隨機(jī)數(shù)的常用方法小結(jié)

    C++中獲取隨機(jī)數(shù)的常用方法小結(jié)

    這篇文章主要為大家詳細(xì)介紹了C++中獲取隨機(jī)數(shù)的幾種常用方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以了解下
    2025-01-01
  • 使用C/C++讀取matlab中.mat格式數(shù)據(jù)的操作

    使用C/C++讀取matlab中.mat格式數(shù)據(jù)的操作

    這篇文章給大家介紹了使用C/C++讀取matlab中.mat格式數(shù)據(jù)的操作,文中通過(guò)圖文結(jié)合的方式介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-12-12
  • opencv實(shí)現(xiàn)棋盤(pán)格檢測(cè)

    opencv實(shí)現(xiàn)棋盤(pán)格檢測(cè)

    這篇文章主要為大家詳細(xì)介紹了opencv實(shí)現(xiàn)棋盤(pán)格檢測(cè),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • 一文總結(jié)C++中的異常

    一文總結(jié)C++中的異常

    異常是一種處理錯(cuò)誤的方式,當(dāng)一個(gè)函數(shù)發(fā)現(xiàn)自己無(wú)法處理的錯(cuò)誤時(shí)就可以?huà)伋霎惓?讓函數(shù)的直接或間接調(diào)用者處理這個(gè)錯(cuò)誤,本文給大家總結(jié)了C++中的異常,需要的朋友可以參考下
    2023-10-10
  • C++入門(mén)之基礎(chǔ)語(yǔ)法學(xué)習(xí)教程

    C++入門(mén)之基礎(chǔ)語(yǔ)法學(xué)習(xí)教程

    這篇文章主要介紹了C++入門(mén)之基本語(yǔ)法學(xué)習(xí)教程,列出了C++的關(guān)鍵字,同時(shí)講解了注釋的寫(xiě)法,需要的朋友可以參考下
    2016-05-05
  • C語(yǔ)言代碼實(shí)現(xiàn)簡(jiǎn)單三子棋游戲

    C語(yǔ)言代碼實(shí)現(xiàn)簡(jiǎn)單三子棋游戲

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言代碼實(shí)現(xiàn)簡(jiǎn)單三子棋游戲,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • C++ QgraphicsScene類(lèi)案例詳解

    C++ QgraphicsScene類(lèi)案例詳解

    這篇文章主要介紹了C++ QgraphicsScene類(lèi)案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • c語(yǔ)言實(shí)現(xiàn)通訊錄管理系統(tǒng)詳細(xì)實(shí)例

    c語(yǔ)言實(shí)現(xiàn)通訊錄管理系統(tǒng)詳細(xì)實(shí)例

    這篇文章主要給大家介紹了關(guān)于c語(yǔ)言實(shí)現(xiàn)通訊錄管理系統(tǒng)的相關(guān)資料,通訊錄管理系統(tǒng)是一種常見(jiàn)的應(yīng)用程序,可以用來(lái)管理聯(lián)系人的信息,包括姓名、電話(huà)號(hào)碼、地址等,需要的朋友可以參考下
    2023-07-07
  • C++11中移動(dòng)構(gòu)造函數(shù)案例代碼

    C++11中移動(dòng)構(gòu)造函數(shù)案例代碼

    C++11 標(biāo)準(zhǔn)中為了滿(mǎn)足用戶(hù)使用左值初始化同類(lèi)對(duì)象時(shí)也通過(guò)移動(dòng)構(gòu)造函數(shù)完成的需求,新引入了 std::move() 函數(shù),它可以將左值強(qiáng)制轉(zhuǎn)換成對(duì)應(yīng)的右值,由此便可以使用移動(dòng)構(gòu)造函數(shù),對(duì)C++11移動(dòng)構(gòu)造函數(shù)相關(guān)知識(shí)感興趣的朋友一起看看吧
    2023-01-01

最新評(píng)論