21

如何找到二维向量的大小?到目前为止,我有以下无法编译的代码。

#include <iostream>
#include <vector>

using namespace std;

int main()
{

    vector < vector <int> > v2d;

    for (int x = 0; x < 3; x++)
    {
        for (int y = 0; y < 5; y++)
        {
            v2d.push_back(vector <int> ());
            v2d[x].push_back(y);
        }
    }

    cout<<v2d[0].size()<<endl;
    cout<<v2d[0][0].size()<<endl;

    return 0;
}
4

4 回答 4

35

要获得v2d的大小,只需使用v2d.size()对于v2d中每个向量的大小,请使用v2d[k].size()

注意:要获得 的整体大小v2d请将每个单独向量的大小相加,因为每个向量都有自己的大小。

于 2010-12-26T17:59:01.907 回答
12

您的代码中有一些错误,我已在下面进行了修复和评论。

vector < vector <int> > v2d;

for (int x = 0; x < 3; x++)
{
    // Move push_back() into the outer loop so it's called once per
    // iteration of the x-loop
    v2d.push_back(vector <int> ());
    for (int y = 0; y < 5; y++)
    {
        v2d[x].push_back(y);
    }
}

cout<<v2d.size()<<endl; // Remove the [0]
cout<<v2d[0].size()<<endl; // Remove one [0]

v2d.size()返回二维向量中的向量数。v2d[x].size()返回 "row" 中的向量数x。如果您知道向量是矩形的(所有“行”的大小相同),您可以使用v2d.size() * v2d[0].size(). 否则,您需要遍历“行”:

int size = 0;
for (int i = 0; i < v2d.size(); i++)
    size += v2d[i].size();

作为更改,您还可以使用迭代器

int size = 0;
for (vector<vector<int> >::const_iterator it = v2d.begin(); it != v2d.end(); ++it)
    size += it->size();
于 2010-12-26T18:03:19.877 回答
10

vector<vector<int>>没有完整的大小,因为其中的每个向量都有独立的大小。您需要对所有包含的向量的大小求和。

int size = 0;
for(int i = 0; i < v2d.size(); i++)
    size += v2d[i].size();
于 2010-12-26T18:01:16.320 回答
2
int size_row = v2d.size();
int size_col = v2d[0].size();
于 2018-04-10T07:14:25.540 回答