unordered-创新互联

Unodered Set

无序集(unorder sets)是一种不按特定顺序存储唯一元素的容器,允许根据元素的值快速检索单个元素。

创新互联建站专业提供成都主机托管四川主机托管成都服务器托管四川服务器托管,支持按月付款!我们的承诺:贵族品质、平民价格,机房位于中国电信/网通/移动机房,成都服务器托管服务有保障!

unordered_set中,元素的值同时也是唯一标识它的键。键是不可变的,因此,unordered_set中的元素在容器中不能被修改,但是它们可以被插入和删除。

在内部,unordered_set中的元素并不按照任何特定的顺序排序,而是根据它们的散列值组织到桶中,从而允许根据它们的值直接快速访问单个元素(平均时间复杂度为常数)。

与set容器相比,Unordered_set容器通过键访问单个元素的速度更快,尽管它们通常在通过元素的子集进行范围迭代时效率较低。


容器的属性 关联性

关联容器中的元素是通过它们的键引用的,而不是通过它们在容器中的绝对位置引用的。

无序性

无序容器使用哈希表组织元素,允许通过键快速访问元素。

具有set特性

元素的值也是用来标识它的键。即value就是key

独一无二的key

容器中没有两个元素具有相同的键。

Allocator-aware

容器使用一个allocator对象来动态地处理其存储需求。即当你插入或者删除数据时,容器会自动处理空间。


常用方法
  • unorder_setfirst容器定义
  • first.empty()判断容器是否是空,是空返回true,反之为false
  • first.size()返回容器大小
  • first.maxsize()返回容器大尺寸
  • first.begin()返回迭代器开始
  • first.end()返回迭代器结束
  • first.find(value)返回value在迭代器的位置
  • first.count(key)返回key在容器的个数
  • first.insert(value)将value插入到容器中
  • first.erase(key)通过key删除
  • first.clear()清空容器

迭代器的使用

#include#include 
#include#include#includeusing namespace std;

int main()
{
	unordered_setmyset = {"Mercury","Venus","Earth","Mars","Jupiter","Saturn","Uranus","Neptune"};
	for (auto it = myset.begin(); it != myset.end(); ++it)
		cout<< *it<< endl;
	return 0;
}

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


网站栏目:unordered-创新互联
文章起源:http://ybzwz.com/article/dpgccj.html