我需要对返回所有出现的向量元素(类似于MATLAB FIND命令)应用FIND功能。虽然无法使用带有迭代器的STL函数找到它,但我编写了这个函数:
vector<int> find(vector<int> v, int value,vector<int>*ive)
{
//Generic Find
vector<int> ve;
for (int i=0;i<v.size();i++)
{
if (v[i]==value)
{
ive->push_back(i);
ve.push_back(v[i]);
}
}
return ve;
}
调用:
//Values
vector<int> v1 = {1,3,3,4,5,2,3,4,6,7,7,8,1,2,2,3,2,2,3,2};
vector<int> iRange,vRange;
int val=2;
//Manual FIND
vRange=find(v1,val,&iRange);
PrintArray(vRange);
PrintArray(iRange);
返回正确的结果:
vRange: 2 2 2 2 2 2
iRange: 5 13 14 16 17 19
当然不使用pair对象,sort()和 *equal_range()* 函数,这将是理想的:
pair<vector<int>::iterator,vector<int>::iterator> Range;
sort(v1.begin(),v1.end());
Range=equal_range(v1.begin(),v1.end(),val);
返回绝对正确但到目前为止完全无用的结果,如果希望结果超过原始的未排序向量:
Range Iters: 2 2 2 2 2 2
Range: 2 3 4 5 6 7
我应该如何使用 STL?
谢谢,炒作