在未排序的向量<int>上查找
Find over an Unsorted vector<int>
我需要对返回所有生成的向量元素(类似于 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
当然,不使用对对象,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?
谢谢炒作
如果我理解你的问题(这是一个很大的"如果"),我认为这将完成你正在寻找的:
#include <iostream>
#include <iterator>
#include <vector>
#include <type_traits>
#include <cstdlib>
using namespace std;
template<typename Iterator>
std::vector<std::pair<Iterator, typename std::iterator_traits<Iterator>::difference_type>> find_range
(
Iterator begin,
Iterator end,
const typename std::iterator_traits<Iterator>::value_type& val
)
{
std::vector<std::pair<Iterator, typename std::iterator_traits<Iterator>::difference_type>> res;
for (Iterator it = std::find(begin, end, val);
it != end; it = std::find(std::next(it), end, val))
res.push_back(std::make_pair(it, std::distance(begin, it)));
return res;
};
int main()
{
vector<int> v1 = {1,3,3,4,5,2,3,4,6,7,7,8,1,2,2,3,2,2,3,2};
auto res = find_range(v1.cbegin(), v1.cend(), 2);
for (auto obj : res)
std::cout << *obj.first << ':' << obj.second << std::endl;
return EXIT_SUCCESS;
}
输出
2:5
2:13
2:14
2:16
2:17
2:19
生成的向量中的每个元素都是一对,其中包含找到该值的迭代器,以及与起始迭代器的距离相对应的差分类型兼容值。这应该适用于提供有效前向迭代器(const 或其他)的任何序列容器。
当然,您可以通过简单地返回带有偏移量的std::vector<>
并通过 std::advance
进行数学运算来做同样的事情,但这可能会变得昂贵。你已经走过一次了。无需再做一次(一次又一次...
希望这就是你要找的。
相关文章:
- 为什么在全局范围内使用"extern int a"似乎不行?
- int(c) 和 c-'0' 之间的区别。C++
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 是否可以从int转换为enum类类型
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 'short int'持有的值溢出,但"自动"不会溢出?
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- 调用'begin(int [n])'没有匹配函数
- 没有显式声明的int[]中的foreach
- 在c++中访问int到类对象的映射时出错
- 为什么我无法更改"set<set>"循环中的值<int>
- EASTL矢量<向量<int>>连续的
- 为什么将此对向量&lt; map&lt; int,int&gt;&gt;中的地图进行更新.失败
- 如何加入向量&lt; int&gt;到C 中的单个INT
- 是numeric_limits&lt; int&gt; :: is_modulo从逻辑上矛盾
- 'structstd::对<int,int>'没有名为'push_back'