gpt4 book ai didi

c++ - 将剩余的项目添加到另一个 vector

转载 作者:行者123 更新时间:2023-11-28 00:11:25 26 4
gpt4 key购买 nike

我有一个 std::vector<unsigned int> v带有一些索引(出于性能目的,我不能使用 std::set

我想创建 v 的否定版本,即具有所有剩余索引的 vector 。如果,在 [0,10] 范围内, v=[0,2,4,6,8] ,我想要否定版本,nv=[1,3,5,7,9] .

备注:v已排序!

这样做最有效的方法是什么?

最佳答案

是线性时间。

std::vector<unsigned int> getnv(unsigned rangebeg, unsigned rangeend, const std::vector<unsigned int>& v)
{
std::vector<unsigned int> nv;
nv.reserve(rangeend - rangebeg - v.size());
std::vector<unsigned int>::const_iterator next = v.begin();
// skip out-of-range values in v
while (next != v.end() && *next < rangebeg) {
++next;
}
for (unsigned i = rangebeg; i < rangeend; ++i)
{
if (next != v.end() && *next == i) {
++next;
continue;
}
nv.push_back(i);
}
return nv;
}

关于c++ - 将剩余的项目添加到另一个 vector ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32928867/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com