【摘要】 数组
1.一维数组
#include<stdio.h>
int main()
{
int arr[10];
return 0;
}1234567
创建一个数组,存放整型10个。[const_n]中的const_n应该是一个常量表达式。
int n=5;
char ch[n];
12
这样的代码是错误的,因为n不是常量。
int main()
{
i…
数组
1.一维数组
#include<stdio.h>
int main()
{
int arr[10];
return 0;
}
创建一个数组,存放整型10个。[const_n]中的const_n应该是一个常量表达式。
int n=5;
char ch[n];
这样的代码是错误的,因为n不是常量。
int main()
{
int arr[10]={1,2,3};//不完全初始化
return 0;
}
这叫不完全初始化,剩下元素默认初始化为0.
#include<stdio.h>
#include<string.h>
int main()
{
char arr[]="abcdef";
printf("%d\n",sizeof(arr));
printf("%d\n",strlen(arr));
return 0;
}
sizeof计算所占空间大小,而strlen计算字符串长度,\0停止并不算\0.
int main()
{
char arr1[]="abc";
char arr2[]={'a','b','c'};
printf("%d\n",sizeof(arr1));
printf("%d\n",sizeof(arr2));
printf("%d\n",strlen(arr1));
printf("%d\n",strlen(arr2));
return 0;
}
int main()
{
int arr[]={1,2,3,4,5,6,7,8,9,10};
int sz=sizeof(arr)/sizeof(arr[0]);
int i = 0;
for(i=0;i<sz;i++)
printf("&arr[%d] = %p\n",i,&arr[i]);
return 0;
}
我们打印出每个元素地址,可以发现每个均差4,因为每个元素都是整型,为四个字节。
结论:数组在内存中是连续存放。
2.二维数组
int main()
{
int arr[3][4];
return 0;
}
定义一个三行四列的数组
int main()
{
int arr[3][4]={1,2,3,4,5};
return 0;
}
这样元素怎么存放呢?我们通过调试
发现第一行放1234,多余的放入第二行,那如果我们想第一行放123,第二行放45怎么操作呢??
int main()
{
int arr[3][4]={{1,2,3},{4,5}};
return 0;
}
通过调试
发现第一行就是123,第二行45
注:行可以省略,列不能省略。
3.二维数组的使用:
int main()
{
int arr[3][4]={{1,2,3},{4,5}};
int i=0;
for(i=0;i<3;i++)
{
int j = 0;
for(j=0;j<4;j++)
{ printf("%d ",arr[i][j]);
}
printf("\n");
}
return 0;
}
int main()
{
int arr[3][4]={{1,2,3},{4,5}};
int i=0;
for(i=0;i<3;i++)
{
int j = 0;
for(j=0;j<4;j++)
{ printf("&arr[%d][%d]=%p\n",i,j,&arr[i][j]);
}
}
return 0;
}
我们发现每个地址仍然差4。也是连续的。
文章来源: blog.csdn.net,作者:Ja_king_,版权归原作者所有,如需转载,请联系作者。
原文链接:blog.csdn.net/Ja_king_/article/details/115752432
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END