标签:stdset c integer range insert
在C中,我有一个std :: set,我想插入一系列连续的整数.我怎样才能有效地做到这一点,希望在O(n)时间内,n是范围的长度?
我想我会使用std :: insert的inputIterator版本,但是我不清楚如何构建输入迭代器.
std::set<int> mySet;
// Insert [34 - 75):
mySet.insert(inputIteratorTo34, inputIteratorTo75);
如何创建输入迭代器,这将是范围大小的O(n)?
解决方法:
将已经排序的元素插入集合的有效方法是提示库到下一个元素的位置.为此你想使用带迭代器的insert版本:
std::set<int>::iterator it = mySet.end();
for (int x : input) {
it = mySet.insert(it, x);
}
另一方面,您可能想要考虑其他容器.尽可能使用std :: vector.如果与查找相比插入量较小,或者所有插入都是预先发生的,那么您可以构建一个向量,对其进行排序并使用lower_bound进行查找.在这种情况下,由于输入已经排序,您可以跳过排序.
如果插入(或删除)遍布整个地方,您可能需要考虑使用std :: unordered_set< int>它具有平均O(1)插入(每个元素)和查找成本.
对于跟踪集合中小数字的特殊情况,所有这些都很小(34到75是小数字),您还可以考虑使用bitset甚至是一个简单的bool数组,在插入时将元素设置为true.要么有O(n)插入(所有元素)和O(1)查找(每次查找),这比集合更好.
标签:stdset,c,integer,range,insert 来源: https://codeday.me/bug/20190725/1533425.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。