如果我想使用 std::list
并且插入到列表中的新元素将插入到与比较功能相关的正确位置 - 我可以这样做吗?或者我必须在每次插入后使用 std::sort ?
原文由 nadavgam 发布,翻译遵循 CC BY-SA 4.0 许可协议
如果我想使用 std::list
并且插入到列表中的新元素将插入到与比较功能相关的正确位置 - 我可以这样做吗?或者我必须在每次插入后使用 std::sort ?
原文由 nadavgam 发布,翻译遵循 CC BY-SA 4.0 许可协议
3 回答2k 阅读✓ 已解决
2 回答3.9k 阅读✓ 已解决
2 回答3.2k 阅读✓ 已解决
1 回答3.2k 阅读✓ 已解决
1 回答2.7k 阅读✓ 已解决
3 回答3.4k 阅读
1 回答1.6k 阅读✓ 已解决
您可以使用:
带有 std::lower_bound 的 std::list:
或者,您可以填充整个 std::vector 并在之后对其进行排序(注意:std::sort 不能对 std::list::iterator 进行操作,它们不提供随机访问):
注意: 手动查找插入位置的列表的性能是最差的 O(N²)。