<span style="font-size:14px;">#include<stdio.h>
#include<stdlib.h>
//二维数组赋值
void show2()
{
int a[3][4];
int k=0;
for(int i=0;i<3;i++)
{
for(int j=0;j<4;j++)
{
a[i][j]=i*4+(j+1);//数学公式 赋值
// a[i][j]= ++k;//与上面效果一致
printf("%-6d",a[i][j]);
}
printf("\n");
}
}
//一维数组赋值
void show1()
{
int a[3][4];
int k=0,count=0;
for(int i=0;i<12;i++)
{
//25/10=2,25%10=5;78/10=7,78%10=8,即除以10得到十位,模10得到个位,相当于一个横坐标x,一个纵坐标y
//以第二个下标为基准 (即除和取余都是以y为运算)
a[i/4][i%4]=i;//一维数组初始化
a[i/4][i%4]=++k;
count++;
printf("%-6d",a[i/4][i%4]);
if(count%4==0)
{
printf("\n");
}
}
}
int main()
{
show2();
show1();
int a[3][4]={0};//二位数组赋值为0,则全部为0
//二维数组可以当做 一个一维数组,每一元素又是一个一维数组
int a[3][4]={{1,2},{5,6,7,8},{9,10,11,12}};
int a[][4]={{1,2,3,4}};//大括号初始化以后,行坐标可以省略
printf("%d\n",sizeof(a));
//列坐标不可以省略,因为二维数组,每一个元素又是一个一维数组,一维数组的长度不能省略
//int a[3][]={{0},{0},{0}};//错误
//N维数组,有大括号初始化有确定的因素,只有第一个可以省略
return 0;
}</span>
二维动态数组
两种模式
第一种整体排序是连续的。与静态二维数组一样使用
第二种整体之间不连续的,一个指针数组,每一个元素都是指针,存放了另外一个数组的地址