Para C ++, ¿cómo devolver el tamaño de una matriz unidimensional o una matriz bidimensional?
Para una matriz unidimensional:
defina una matriz por int a []:
#include <iostream>
#include <vector>
using namespace std;
int main()
{
int a[] = {
1,2,3,4,5,6 };
int n = sizeof(a) / sizeof(a[0]); //n为数组长度
cout << n;
return 0;
}
Utilice contenedores de vectores para abrir el espacio de la matriz
#include <iostream>
#include <vector>
using namespace std;
int main()
{
vector<int> nums;
nums.push_back(1); //赋值操作自由选择,此处只做样例
nums.push_back(2);
nums.push_back(3);
nums.push_back(4);
nums.push_back(5);
nums.push_back(6);
int n = nums.size();
cout << n;
}
Para una matriz bidimensional
//通过int a[][] 来定义一个二维数组
#include <iostream>
#include <vector>
using namespace std;
int main()
{
int a[2][3] = {
{
1,2,3},{
1,2,3} };
int sum = (sizeof(a) / sizeof(int));
int row = (sizeof(a) / sizeof(int)) / (sizeof(a[0]) / sizeof(int)); //注意加括号
int column = sizeof(a[0]) / sizeof(int); //等价于 int column=sum/row;
cout << sum << endl;
cout << row << endl;
cout << column << endl;
return 0;
}
Defina una matriz bidimensional a través de un vector y devuelva los rangos de la matriz
#include <iostream>
#include <vector>
using namespace std;
int main()
{
vector<vector<int> > matrix = {
{
1,2,3},{
4,5,6} };
int row = matrix.size();//行数
int column = matrix[0].size();//列数
cout << row << endl;
cout << column << endl;
return 0;
}