C++-STL(6)-map-set -有序-增删改查

map<key,value> key 不同,value可同,有序。
set<key>            key不同 ,                       有序 。 用于整数去重排序最好不过了。不能改值。
代码亲测可行,自己MARK一下,也供大家参考。

map
 

void maptest()
{
	//1.定义 map<char, int> mymap;
	//2.插入insert pair<,>
	//3.得到大小 int nSize = mymap.size();
	//4.查找 iter=mymap.find()   输入key 返回iter
	//5.删除 int n=mymap.erase(key) 返1 成功;返0 不成功
	//6.删除全部 mymap.erase(mymap.begin(), mymap.end());
	//7.修改mymap['d']=4000;
	cout<<"map 增删改查 ******"<<endl;

	cout << "1定义 map<char, int> mymap;" << endl;
	cout << " 2插入insert pair<,>" << endl;
	map<char, int> mymap;
	mymap.insert(pair<char, int>('a', 100));
	mymap.insert(pair<char, int>('z', 200));
	mymap.insert(pair<char, int>('b', 300));
	mymap['d'] = 400;
	mymap.insert(map<char, int>::value_type('f', 500));
	map<char, int>::iterator iter;
	for (iter = mymap.begin(); iter != mymap.end(); iter++)
	{
		cout << iter->first << " " << iter->second << endl;
	}
	
	cout << " 3得到大小 int nSize = mymap.size();" << endl;
	int nSize = mymap.size();
	cout << nSize << endl;
	cout << "4.查找 iter=mymap.find(b)   输入key 返回iter" << endl;
	  iter = mymap.find('b');
	  cout << iter->first << " " << iter->second << endl;

	cout << "5.删除 int n=mymap.erase(key) 返1 成功;返0 不成功" << endl;
	int n = mymap.erase('b');
	cout << "删除后的返回值="<<n << endl;
	for (iter = mymap.begin(); iter != mymap.end(); iter++)
	{
		cout << iter->first << " " << iter->second << endl;
	}
	cout << "6.修改mymap['d']=4000;" << endl;
	mymap['d'] = 4000;
	cout << mymap['d'] << endl;

	cout << "7.删除全部 mymap.erase(mymap.begin(), mymap.end());" << endl;
	 mymap.erase(mymap.begin(), mymap.end());
	  nSize = mymap.size();
	 cout << "删除全部后map的长度"<<nSize << endl;

}



set
 

void settest()
{
	//1.定义 set<int> myset;
	//2.插入insert <key>
	//3.得到大小 int nSize = myset.size();
	//4.查找 iter=myset.find(key)   输入key 返回iter
	//5.定位 iter=lower_bound(key)  <=key 返回iter
	//  定位 iter = upper_bound(key) >=key 返回iter
	//6.删除 int n=myset.erase(key) 返1 成功;返0 不成功
	// 删除全部 mymap.clear();
	
	    cout << "1.定义 set<char, int> myset;" << endl;
		set<int> myset;
		myset.insert(1);
		myset.insert(2);
		myset.insert(10);
		myset.insert(100);
		myset.insert(4);
		myset.insert(8);
		myset.insert(9);
		cout << "2.插入insert <key>" << endl;
		set<int>::iterator iter;
		for (iter = myset.begin(); iter != myset.end(); iter++)
		{
			cout << *iter << endl;
		}
		cout << "auto 类型遍历" << endl;
		for (auto iter1 = myset.begin(); iter1 != myset.end(); iter1++)
		{
			cout << *iter1 << endl;
		}
			
		cout << "3.得到大小 int nSize = myset.size();" << myset.size() << endl;
		cout << "4.查找 iter=myset.find(key)   输入key 返回iter"   <<endl;
		      iter = myset.find(100);
		      cout << *iter << endl;

		cout << "5.定位 iter=lower_bound(key)  <=key 返回iter  第一个" << endl;
		iter = myset.lower_bound(100);
		cout << *iter << endl;
		cout << "6  定位 iter = upper_bound(key) >=key 返回iter 第一个" << endl;
		iter = myset.upper_bound(10);
		cout << *iter << endl;
		cout << "6.删除 int n=myset.erase(key) 返1 成功;返0 不成功" << endl;
		cout << "int n="<<myset.erase(8) << endl;
		for (auto iter1 = myset.begin(); iter1 != myset.end(); iter1++)
		{
			cout << *iter1 << endl;
		}
		cout << " 删除全部 myset.clear();" << endl;
		myset.clear();
		cout << "删除后大小 int nSize = myset.size();" << myset.size() << endl;
	
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
STL是指标准模板库(Standard Template Library),它是C++语言的一部分,提供了一系列的模板类和函数,用于支持通用的数据结构和算法。STL的目标是提供高效、可重用和可扩展的组件,以便开发人员能够更轻松地编写高质量的代码。STL包含了许多常见的数据结构,如vector、list、setmap等,以及各种算法,比如排序、查找、遍历等。通过使用STL,开发人员可以更加高效地处理各种数据结构和算法的问题,提高代码的开发效率和质量。 在STL中,我们可以使用各种容器来存储和管理数据。例如,我们可以使用std::map来创建一个键值对的映射,其中每个键都有一个与之相关联的值。下面是一个示例代码,展示了如何创建和使用一个std::map对象: std::map<std::string, int> disMap() { std::map<std::string, int> tempMap{ {"C语言教程",10},{"STL教程",20} }; return tempMap; } std::map<std::string, int> newMap(disMap()); 在这个示例中,disMap()函数创建了一个临时的std::map对象,并初始化了其中的一些键值对。然后,使用移动构造函数将这个临时对象移动到了一个新的std::map对象newMap中。最终,我们可以通过newMap对象来访问和操作这些键值对。 综上所述,STLC++中的标准模板库,提供了一系列的模板类和函数,用于支持通用的数据结构和算法。STL的使用可以提高代码的开发效率和质量,并且通过各种容器和算法,可以方便地处理各种数据结构和算法的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [C++ STL详解超全总结(快速入门STL)](https://blog.csdn.net/qq_50285142/article/details/114026148)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【C++实验】阅读STL源码并分析](https://blog.csdn.net/qq_35760825/article/details/125311509)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值