unordered_set
将字符通过哈希函数转成数组的下标,然后将字符存放在下标处,这样我们可快速查找到字符,
set容器不可以有重复的元素
1、初始化
unordered_set<char>set;//构造一个空的容器
unordered_set<char>set(str.begin(),string.end());//将一个字符串str初始化set容器
2、插入、查找、遍历
unordered_set<int> set;
for(int i = 0; i < list.size(); i++){
set.insert(list[i]);
for(unordered_set<int> :: iterator i = set.begin(); i != set.end(); i++)
{
cout << *i << endl;
}
cout << "find 39" << *set.find(39) << endl;
cout << "count 14" << set.count(5) << endl;//找到就返回1
}
for(unordered_set<int> :: iterator i = set.begin(); i != set.end(); i++)//创建出一个迭代器
{
cout << *i <<endl;
}
unordered_map
将字符串通过哈希函数转成数组的下标,然后我们可以在这个地方存放数据(出现次数之类的,也可以放别的)
1、构造函数
unordered_map<int,int>map;//构造空的容器
unordered_map<string,int>map{{"jan",44},{"jim",33},{"joe",99}};//直接构造
unordered_map<string,int>map(hashmap,begin(),hashmap.end());//范围初始化
2、插入、查找、遍历
map.insert(pair<string,int>)(word,1);//map容器中直接添加数据
unordered_map<int,int> map;
for(int i = 0; i < list.size(); i++)
map[i] = list[i]//将数据写入map中
cout << map[0] << endl;
for(unordered_map<int,int>::iterator i = map.begin(); i != map.end(); i++)//创建出一个迭代器
cout << i ->first << ' ' << i ->second << endl;
if(map.find(3) != map.end())//map.find(3)会返回一个迭代器
cout <<"find key = " << map.find(3)->first << " value =" << map.find(3)->second <<endl;
if(map.count(5) > 0)
cout << "find 5: " << map.count(5) <<endl;//要是找到就返回1,不然就返回0