C++ std::multiset 删除 查找 重复元素中的特定元素

Posted 软件工程小施同学

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C++ std::multiset 删除 查找 重复元素中的特定元素相关的知识,希望对你有一定的参考价值。

#include <iostream>
#include <set>
using namespace std;
 
class stru{
	public:
   	 	stru(int a, int b): x(a), y(b){}
		int x;
   	 	int y;
};
 
bool operator<(const stru& a, const stru& b)    //比较的是x的值
{
    return a.x < b.x;
}
 
int main()
{
    //创建
    multiset<stru> st;
    
    //插入
	st.emplace(stru(8, 38));
	st.emplace(stru(8, 39));
    st.emplace(stru(9, 40));   //添加成功,因为multiset可以有重复的值,也就是说有x = 10的stru也可以。
    st.emplace(stru(9, 41));    //添加成功
	st.emplace(stru(10, 42));
	st.emplace(stru(10, 43));
	st.emplace(stru(10, 44));
	auto res = st.emplace(stru(10, 45));
	
    
    //查看
    for (auto it = st.rbegin(); it != st.rend(); it++)   //10-40 9-43 9-45 8-40 7-35 6-30 5-25 4-20 3-15 2-10 1-5 0-0
        cout<<(*it).x<<"-"<<(*it).y<<" ";
    cout<<endl;
    
    // 查找,查找出符合比较函数的第一项
    auto it = st.find(stru(10, 43));           //和上面一样,只会找x = 9的第一项。
    cout<<"查找出符合比较函数的第一项:"<< it->x <<" "<<it->y<<endl;             // 返回10,42
	
	
	// 迭代器、查看
    cout<<"迭代器可以找出确定项:"<<(*res).x<<"-"<<(*res).y<<endl;
	
	// 删除,所有符合条件都会被删除
	st.erase(stru(9, 40));
	//查看
    for (auto it = st.rbegin(); it != st.rend(); it++)   //10-40 9-43 9-45 8-40 7-35 6-30 5-25 4-20 3-15 2-10 1-5 0-0
        cout<<(*it).x<<"-"<<(*it).y<<" ";
    cout<<endl;
	
	
	// 删除迭代器,只删除特定项
	st.erase(res);
	//查看
    for (auto it = st.rbegin(); it != st.rend(); it++)   //10-40 9-43 9-45 8-40 7-35 6-30 5-25 4-20 3-15 2-10 1-5 0-0
        cout<<(*it).x<<"-"<<(*it).y<<" ";
    cout<<endl;
	
	
    
}

 

以上是关于C++ std::multiset 删除 查找 重复元素中的特定元素的主要内容,如果未能解决你的问题,请参考以下文章

C++ std::multiset find 返回值不对

std::multimap::find 将返回哪个元素,类似地 std::multiset::find?

std::unordered_multiset 的用例

为啥使用 std::multiset 作为优先级队列比使用 std::priority_queue 更快?

如何在不重载 `operator()`、`std::less`、`std::greater` 的情况下为`std::multiset` 提供自定义比较器?

在 std::multiset 中,如果找到一个元素,是不是有一种函数或算法可以只擦除一个样本(单一或重复)