我有一个矢量std :: vector。我想迭代向量找到匹配,如果找到想要返回指向元素的指针,如下所示:
const int * findint(std::vector <int> &v, int a)
{
std::vector<int>::const_iterator i1,i2;
i1 = v.begin();
i2 = v.end();
for(;i1 != i2;++i1) {
if(a== *i1) {
return(i1);
}
}
return(0);
}
这是使用GNU g ++ 2.95.3编译器进行编译和工作正常但没有使用GNU g ++ 4.9.2进行编译并出现以下错误:
error: cannot convert 'std::vector<GenFld>::const_iterator {aka __gnu_cxx::__normal_iterator<const int*, std::vector<int> >}' to 'const int*' in return
[exec] return(i1);
需要帮助。
答案 0 :(得分:12)
这将解决您的问题:
get_template_directory_uri
修改:请注意,我将迭代器更改为const int * findint(const std::vector <int> &v, int a){
auto i1 = v.cbegin();
auto i2 = v.cend();
for(;i1 != i2;++i1){
if(a == *i1){
return &*i1;
}
}
return nullptr;
}
和cbegin
,cend
现在又作为vector
传递。
然而,正确的做法IMO(关于nathanoliver注意):
const
使用它时必须小心。在向量上的任何auto it = std::find(v.cbegin(),v.cend(),value);
decltype(&*it) ptr;
if(it==v.cend()){
ptr = nullptr;
}
else{
ptr = &*it;
}
或push_back
或insert
之后,指针和迭代器可能无效,有关综合列表,请参阅Iterator invalidation rules。如果你想保留一些线索,以便以后到达某个项目。如果你能保证只会添加到向量的后面,你可以使用以下方法保留项目的索引:
erase
答案 1 :(得分:1)
你可以做这样的事情
auto i1 = std::find(v.begin(), v.end(), a);
if(i1 != v.end())
{
index = std::distance(v.begin(), i1);
return(&v[index])
}
else
{
return NULL;
}
答案 2 :(得分:1)
使用v.data()
:
const int * findint(const std::vector <int> &v, int a)
{
const int * const b = v.data();
const int * const e = b + v.size();
const int * const r = std::find(b, e, a);
return (r == e) ? nullptr : r;
}