比较一个向量中向量的大小,得到最大的
Compare sizes of vectors in a vector to get the largest
如何比较存储在矢量中的矢量的大小以获得最大的矢量?
假设我有5个不同大小的整数向量(有些可能有相同的大小)。实际上,在我的游戏中可能会有几百个整数向量。
vector <int> v1;
vector <int> v2;
vector <int> v3;
vector <int> v4;
vector <int> v5;
我有一个存储上面的5个int型向量的向量
vector <vector <int> > vAllvects;
我可以计算出vAllvects向量存储的5个向量的大小
for(vector < vector < int > > :: size_type iter = 0; iter < vAllvects.size() ; iter++ )
{
cout << " vAllvects[" << iter << "] size is " << vAllvects[iter].size() << endl ;
for(vector < vector < int > > :: size_type x = 0; x < v. Allvects[iter].size() ; x++)
{
}
cout << endl;
}
我需要的是一个或多个最大的向量
如何比较vAllvects向量的每个元素中的每个向量大小以获得最大大小的向量?
对于这类事情通常有标准的库算法。在这种情况下,您可以使用std::max_element
和合适的二进制谓词:
auto max_iterator = std::max_element(std::begin(vAllvects),
std::end(vAllvects),
[](const std::vector<int>& lhs,
const std::vector<int>& rhs)
{
return lhs.size() < rhs.size();
});
这里,max_iterator
是指向最大向量的迭代器,如果有多个最大向量,则指向第一个。
只需遍历包含向量的向量,通过例如指针跟踪最大的向量。例如:
unsigned int largestSize = 0;
vector<int>* largestVect = 0;
for(unsigned int i=0; i<vAllvects.size(); ++i) {
if(vAllvects[i].size() > largestSize) {
largestSize = vAllvects[i].size();
largestVect = &vAllvects[i];
}
}
现在你有一个指向最大向量的指针
相关文章:
- 函数向量_指针有不同的原型,我可以构建一个吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 为什么我不能将一个对象push_back到属于另一个类的对象向量中?
- 给定一个向量,如何找到该向量的所有子集和的原始索引
- 获取向量C++中第一个值和最后一个值的和
- 从多个源构造一个对象,包括一个对象向量
- 为什么一个向量上的多线程操作很慢
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- C++ - 如何在结构向量中找到结构体一个成员的最大值?
- 如何在 C++11 中查找和更新向量中的一个嵌套结构
- Lower_bound不适用于具有 3 个元素的向量的最后一个元素
- 将一个向量插入另一个向量的某个位置
- std::find,返回所有找到的值的替代方法,而不仅仅是存在重复的向量的第一个值
- 将指向给定子类的指针从一个向量复制到另一个向量
- 如何创建一个类,以便向量工作 std::vector<MyClass<int>> v{ 1,2,3 };
- C++ STD 函数运算符:有没有一种方法可以通过函数将一个向量映射到另一个向量上?
- 将向量之间的数字放在另一个向量之间<vector>>如果两个数字的差值为 1
- 如何在不复制的情况下将一个向量移动到另一个向量中
- 创建一个函数的 Python 绑定,返回指向带有 boost 的向量的指针
- 紧凑向量一个小的内存足迹向量