在c++中将两个相关的std::堆栈合并为std::map的计算效率如何?
What is the computationally efficient way to merge two associated std::stack into a std::map in C++
我有一个函数,它生成两个元素之间一对一对应的关联值的std::stack
s。为了便于在函数之间传递值,我希望将两个堆栈合并为一个map。
到目前为止,我在堆栈中弹出每个元素,形成std::pair
并将其插入std::map
中,如下所示:
/* peaks_x and peaks_y are the stacks that I
want to merge into the map called peaksmap which is
given as argument to this function */
/* create the stacks*/
std::stack<int> peaks_x;
std::stack<float> peaks_y;
/* the following function populates the values needed */
populatepeakvalues(&peaks_x,&peaks_y);
/* merging here into a map*/
while(!peaks_x.empty() && !peaks_y.empty() ) {
peaksmap->insert(std::pair<int,float>(peaks_x.top(),peaks_y.top()));
peaks_x.pop();
peaks_y.pop();
}
这是最好的方法还是有更快的计算方法?可能在使用指针?
注意:我不能编辑函数populatepeakvalues
输出映射,因为我没有权限。
在不进入杂草的情况下很难打败它。对于普通的旧std::stack
,后备存储是std::deque
。pop()
操作只是移动一个指向队列末尾的指针。这意味着你只是在后台使用指针。
std::deque
,这通常是最糟糕的访问内存的方式。对于小型std::stack
来说,这无关紧要。对于较大的std::stack
,内存带宽将使循环变慢。您可能能够通过创造性的黑客直接访问嵌入式std::deque
来解决这个问题。那个将会使你的保修无效。
相关文章:
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 使用一个考虑到std::map中键值的滚动或换行的键
- 有没有办法对std::unordered_set、std::unrdered_map、std::set、std::map
- 将重物插入std::map
- 使用通用值初始化 std::map,不重复
- 仅包含可移动 std::map 的类的移动构造函数不起作用
- C++:当所有条目都保证是唯一时,替代 std::map
- 使用模板化的键类型定义 std::map,该键类型基于作为参数接收的函数
- 如果 KEY 是 std::list 或 std::vector 而不是值,那么 std::map 的默认行为是什么?
- C++如何创建 std::map
- 从其他容器中移动构造"std::map"
- 将 std::map::emplace 与返回 shared_ptr 的函数一起使用是否正确?
- C++中 std::map 的运行时复杂度是多少?
- 为什么在 std::map 上移动无法将元素从一个映射移动到另一个映射
- 使用重载 [] 运算符返回 std::map() 的可赋值
- std::map, std::unordered_map - 缩小初始值设定项列表中的转换范围
- C++ 使用枚举类对象分配 std::map 值
- 静态 std::map instatiation 在类的方法中调用构造函数吗?
- std::map:当元素不可默认构造时创建/替换元素
- Arduino编译器和STL:使用std::vector和std::map