黑马c++ STL部分 笔记(8) set/ multiset 容器

2024-03-02 19:28

本文主要是介绍黑马c++ STL部分 笔记(8) set/ multiset 容器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介
所有元素都会在插入时自动被排序
本质
set/multiset属于关联式容器,底层结构是用二叉树实现。
set和multiset区别
set允许容器中有重复的元素
multiset允许容器中有重复的元素

 1.set构造和赋值

// set构造和赋值
/*
构造:
set<T> st; //默认构造函数:
set(const set &st); //拷贝构造函数
赋值:
set& operator=(const set &st); //重载等号操作符
*/
#include <bits/stdc++.h>
using namespace std;
void printset(set<int> &s)
{for (set<int>::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{set<int> s1;s1.insert(10); // 插入数据只有insert方式s1.insert(30);s1.insert(40);s1.insert(20);s1.insert(30);// set里的元素自动被排序,不允许插入重复的值printset(s1); // 10 20 30 40// 拷贝构造set<int> s2(s1);printset(s2); // 10 20 30 40// 赋值set<int> s3;s3 = s2;printset(s3); // 10 20 30 40
}
int main()
{test01();
}
/*
总结:
set容器插入数据时用insert
set容器插入数据的数据会自动排序
*/

2. set大小和交换

// set大小和交换
/*不支持resize
size(); //返回容器中元素的数目
empty(); //判断容器是否为空
swap(st); //交换两个集合容器
*/
#include <bits/stdc++.h>
using namespace std;
void printset(set<int> &s)
{for (set<int>::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{set<int> s1;s1.insert(10);s1.insert(30);s1.insert(40);s1.insert(20);s1.insert(30);printset(s1); // 10 20 30 40if (s1.empty()){cout << "s1为空" << endl;}else{cout << "s1为不空" << endl;cout << s1.size() << endl; // 4}set<int> s2;s2.insert(10);printset(s2); // 10s1.swap(s2);printset(s1); // 10printset(s2); // 10 20 30 40
}
int main()
{test01();
}
/*
总结:
统计大小 — size
判断是否为空 — empty
交换容器 — swap
*/

 3.set插入和删除

// set插入和删除
/*
insert(elem); //在容器中插入元素。
clear(); //清除所有元素
erase(pos); //删除pos'迭代器'所指的元素,返回下一个元素的迭代器。
erase(beg, end); //删除区间[beg,end)的所有元素 ,返回下一个元素的迭代器。
erase(elem); //删除容器中'值'为elem的元素。(类似remove)
*/
#include <bits/stdc++.h>
using namespace std;
void printset(set<int> &s)
{for (set<int>::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{set<int> s1;// 插入s1.insert(30);s1.insert(10);s1.insert(40);s1.insert(20);s1.insert(30);printset(s1); // 10 20 30 40// 删除迭代器位置s1.erase(s1.begin());printset(s1); // 20 30 40// 删除元素s1.erase(40);printset(s1); // 20 30// 清空s1.clear();printset(s1);
}
int main()
{test01();
}
/*
总结:
插入 — insert
删除 — erase
清空 — clear
*/

4.set查找和统计 

// set查找和统计
/*
find(key); //查找key是否存在,若存在,返回该键的元素的'迭代器';若不存在,返回'set.end()';
count(key); //统计key的'元素'个数  set中返回0/1 multiset为0/>0的值
*/
#include <bits/stdc++.h>
using namespace std;
void printset(set<int> &s)
{for (set<int>::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{set<int> s1;// 插入s1.insert(30);s1.insert(10);s1.insert(40);s1.insert(20);s1.insert(30);printset(s1); // 10 20 30 40// 查找set<int>::iterator pos = s1.find(40);if (pos != s1.end()){cout << "找到元素:" << *pos << endl; // 找到元素:40}else{cout << "未找到元素:" << endl;}// 统计int num = s1.count(30); // 统计30的个数cout << num << endl;    // 1
}
int main()
{test01();
}
/*
总结:
查找 — find (返回的是迭代器)
统计 — count (对于set,结果为0或者1)
*/

5.set和multiset区别 

// set和multiset区别
/*
区别:
set不可以插入重复数据,而multiset可以
set插入数据的同时会返回插入结果,表示插入是否成功
multiset不会检测数据,因此可以插入重复数据
*/
#include <bits/stdc++.h>
using namespace std;
void test01()
{set<int> s;// set插入pair<set<int>::iterator, bool> ret = s.insert(10);if (ret.second){cout << "第一次插入成功" << endl; // √}else{cout << "第一次插入失败" << endl; // ×}// set重复插入ret = s.insert(10);if (ret.second){cout << "第二次插入成功" << endl; // ×}else{cout << "第二次插入失败" << endl; // √}multiset<int> s2;// multiset插入s2.insert(10);// multiset重复插入s2.insert(10);for (multiset<int>::iterator it = s2.begin(); it != s2.end(); it++){cout << *it << " "; // 10 10}
}
int main()
{test01();
}
/*
总结:
如果不允许插入重复数据可以利用set
如果需要插入重复数据利用multiset
*/

6. pair对组创建

// pair对组创建
/*
两种创建方式:
pair<type, type> p ( value1, value2 );
pair<type, type> p = make_pair( value1, value2 );
*/
#include <bits/stdc++.h>
using namespace std;
void test01()
{pair<string, int> p("Tom", 20);cout << p.first << " " << p.second << endl; // Tom 20pair<string, int> p2 = make_pair("Jerry", 15);cout << p2.first << " " << p2.second << endl; // Jerry 15
}
int main()
{test01();
}
/*
总结:
两种方式都可以创建对组,记住一种即可
*/

7.1  set容器排序
示例一 set存放内置数据类型 

//  set容器排序
/*
学习目标:
set容器默认排序规则为从小到大,掌握如何改变排序规则
主要技术点:
利用仿函数,可以改变排序规则
*/
// 示例一 set存放内置数据类型
#include <bits/stdc++.h>
using namespace std;
class cmp // 仿函数(类)
{
public:bool operator()(int v1, int v2){return v1 > v2;}
};
void test01()
{// 升序set<int> s1;s1.insert(10);s1.insert(30);s1.insert(20);s1.insert(50);s1.insert(40);for (set<int>::iterator it = s1.begin(); it != s1.end(); it++){cout << *it << " "; // 10 20 30 40 50}cout << endl;// 降序,在创建容器时就指定排序规则set<int, cmp> s2;s2.insert(10);s2.insert(30);s2.insert(20);s2.insert(50);s2.insert(40);for (set<int, cmp>::iterator it = s2.begin(); it != s2.end(); it++){cout << *it << " "; // 50 40 30 20 10}cout << endl;
}
int main()
{test01();
}
/*
总结:
对于自定义数据类型,set必须指定排序规则才可以插入数据
*/

7.2  set容器排序
示例二 set存放自定义数据类型 

//  set容器排序
// 示例二 set存放自定义数据类型
#include <bits/stdc++.h>
using namespace std;class person
{
public:person(string name, int age){this->name = name;this->age = age;}string name;int age;
};
class cmp
{
public:bool operator()(person p1, person p2){// 按年龄降序return p1.age > p2.age;}
};
void test01()
{/// 自定义的类型 都会指定排序类型set<person, cmp> s;person s1("刘备", 24);person s2("关羽", 28);person s3("张飞", 25);person s4("赵云", 21);s.insert(s1);s.insert(s2);s.insert(s3);s.insert(s4);for (set<person, cmp>::iterator it = s.begin(); it != s.end(); it++){cout << (*it).name << " " << (*it).age;/*关羽 28张飞 25刘备 24赵云 21*/cout << endl;}
}
int main()
{test01();
}
/*
总结:
对于自定义数据类型,set必须指定排序规则才可以插入数据
*/

这篇关于黑马c++ STL部分 笔记(8) set/ multiset 容器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/767194

相关文章

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

如何将Tomcat容器替换为Jetty容器

《如何将Tomcat容器替换为Jetty容器》:本文主要介绍如何将Tomcat容器替换为Jetty容器问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat容器替换为Jetty容器修改Maven依赖配置文件调整(可选)重新构建和运行总结Tomcat容器替

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑