二维数组的基本操作
定义和初始化
int a[2][3] = { 1,2,3,4,5,6 };//表示一个两行三列的矩阵;
int a[2][3] = { {1,2},{4} };//{1,2}为第一行,{4}为第二行,没有的元素自动用0填充;
int a[][3]= { 1,2,3,4,5,6 };//可以省略第一维的大小,但是第二维的大小必须写;
遍历
二维数组的遍历需要用两次for循环;
#include<iostream>
using namespace std;
int main()
{
int a[2][3] = { 1,2,3,4,5,6 };
int i, j;
for (i = 0; i <= 1; i++)
{
for (j = 0; j <= 2; j++)
cout << a[i][j] << ",";
cout<<endl;
}
system("pause");
return 0;
}
求数组的最大值
方法一,直接利用二维数组求解
#include<iostream>
using namespace std;
int maxa(int[][3], int,int);
int main()
{
int a[2][3] = { 1,2,3,4,5,6 };
int d;
d = maxa(a, 2, 3);//a表示数组的首地址;
cout << "数组中最大数是:" << d << endl;
system("pause");
return 0;
}
int maxa(int g[][3], int a1, int a2)
{
int max=0;
for (int i = 0; i < a1; i++)
for (int j = 0; j < a2; j++)
if (g[i][j] > max)
max = g[i][j];
return max;
}
方法二,将二维转化为一维数组,然后解决问题
#include<iostream>
using namespace std;
int maxa(int[],int);
int main()
{
int a[2][3] = { 1,2,3,4,5,6 };
int d;
d = maxa(&a[0][0], 2* 3);//&取地址,&a[0][0]表示数组的首地址;
cout << "数组中最大数是:" << d << endl;
system("pause");
return 0;
}
int maxa(int g[], int a1)
{
int max=0;
for (int i = 0; i < a1; i++)
if (g[i] > max)
max = g[i];
return max;
}
二维vector操作
基本操作
//定义
vector<vector<int> >a;//注意空格;
vector<vector<int> > a(20);//
vector<int> b;
b.push_back(10);
b.push_back(20);
a.push_back(b);
b.clear();
b.push_back(1);
b.push_back(3);
a.push_back(b);
//数组长度;
int len1=a.size();//a中vector的数量
int len2=a[i].size();//a中第i个vector中元素数量。
//数组访问
cout<<a[i][j];//直接访问数组元素