带有结构映射的 C++ 向量?
c++ vector with struct to map?
我有一个这个结构的向量:
struct AB
{
int id, x, y;
}
x 和 y 是坐标。 向量中的数据如下所示:
- 内径 22 x 53.2 y 8.90
- 内径 22 x 53.3 y 8.91
- 内径 25 x 53.4 y 8.92 ...
您可以看到某些 id 包含多个坐标。因此,我正在寻找一种以不同形式保存数据的方法。哪个更适合进一步处理数据。有人给小费吗?
这完全取决于您如何填写和使用数据。如果一开始就一次性加载所有数据,然后只使用加载的数据,那么保留向量,加载所有数据,根据 ids 对其进行一次排序,然后使用排序后的向量实际上是有益的 - 因为连续块具有更好的局部性,因此更好的缓存行为(与暗示到处追逐指针的有序或无序映射结构相反这个地方,不是很适合缓存(。如果很少添加新项,这也行得通。请注意,只要排序后不需要添加新项目,这将具有与平衡的基于树的映射相同的 big-O(如果您要在排序向量中进行二叉搜索(。
如果经常添加新项目,则可以使用 std::multimap(或基于哈希工作的无序(,或点向量的映射/unordered_map。
决定哪一个更适合您应该基于当前速度和更改后速度的测量(您通常不希望"改进"版本比原始版本慢(。
相关文章:
- 写入向量<向量<bool>>
- 函数向量_指针有不同的原型,我可以构建一个吗
- std::向量与传递值的动态数组
- 将值指定给向量(2D)的向量中的某个位置
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 如何使用向量的template_back函数
- 尝试通过多个向量访问变量时,向量下标超出范围
- 如何通过派生类函数更改基类中的向量
- C++从另一个类访问公共静态向量的正确方法是什么
- 如何将ampl中的集合表示为c++中的向量
- 变量没有改变?通过向量的函数调用
- 迭代时从向量和内存中删除对象
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 计算排序向量的向量中唯一值的计数
- 矩阵向量乘法(cublasDgemv)返回零
- 一对向量构造函数:初始值设定项列表与显式构造
- 将结构向量排序为子组
- 在C++中调整向量中的索引
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么