当前位置:   article > 正文

C语言学习NO.6-二维数组的概念、创建、初始化、使用、存储_c语言采用行初始化形式为二维表格创建二维数组

c语言采用行初始化形式为二维表格创建二维数组

一、二维数组的创建

(一)二维数组的概念

将一维数组作为数组的元素,这时候就是二维数组,二维数组作为数组元素的数组被称为三维数组,二维数组以上的数组统称为多维数组。

b34a75ae89474e2eacecb3d1e168363f.png

(二)二维数组的创建

  1. tyape arr_name[常量值1][常量值2];
  2. //例如:
  3. int arr[3][5];
  4. double data[2][8];
  • [3][5]表示数组有三行,每一行元素有五个
  • int表示数组的每个元素都是整型类型;
  • arr是数组名,可以根据需要指定名字;
  • double data[2][8];//同样解读

二、二维数组的初始化

二维数组的初始化,像一维数组一样,也是使用大括号初始化的。

  1. //不完全初始化
  2. int arr1[3][5] = {1,2};
  3. int arr2[3][5] = {0};
  4. //完全初始化
  5. int arr3[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};
  6. //每五个连续的元素是一行
  7. //按照行初始化,将一维数组看作每一行的元素
  8. int arr4[3][5] = {{1,2},{3,4},{5,6}};
  9. //初始化时省略行,但是不能省略列
  10. int arr5[][5] = {1,2,3};
  11. int arr6[][5] = {1,2,3,4,5,6,7};
  12. int arr7[][5] = {{1,2},{3,4},{5,6}};

三、二维数组的使用

(一)二维数组的下标

二维数组的访问也是使用下标的形式的,二维数组是有行和列的,只要锁定了行和列就能唯一锁定数组中的一个元素。

C原因规定,二维数组的行是从0开始的,列也是从0开始的,如下所示:

int arr[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};

8ccf021ebd004f42a27a431e9605fe84.png

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int arr[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};
  5. printf("%d\n",arr[2][4]);
  6. return 0;
  7. }

结果为:86fadcb2a12c445f8ab63b8dc0e3e7ad.png

(二)二维数组的输入和输出

如何访问二维数组?

套用输出一维数组的代码,将数组的行和列分别用循环写出。

同样通过下标来访问二维数组的元素,例如设 i 为行的下标,j 为列的下标。用一个循环套住另一个循环,当 i = 1 时,另 j 在1,2,3……n中循环,这样就完成了第一行第n个元素(n为一个确定的数),再依次循环 i = 2,3……。

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int arr[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};
  5. int i = 0;
  6. //输入
  7. for(i=0; i<3; i++)
  8. {
  9. int j = 0;
  10. for(j=0; j<5;j++)
  11. {
  12. scanf("%d",&arr[i][j]);
  13. }
  14. }
  15. //输出
  16. for(i=0; i<3; i++)
  17. {
  18. int j = 0;
  19. for(j=0; j<5;j++)
  20. {
  21. printf("%d ",arr[i][j]);
  22. }
  23. printf("\n");
  24. }
  25. return 0;
  26. }

输出结果为:17a17950fb824e3eb4e03f78db06ab53.png

四、二维数组在内存中的存储

研究二维数组在内存中的存储方式,从数组所有元素的地址下手:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int arr[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};
  5. int i = 0;
  6. for(i=0; i<3; i++)
  7. {
  8. int j = 0;
  9. for(j=0; j<5; j++)
  10. {
  11. printf("&arr[%d][%d] = %p\n",i,j,&arr[i][j]);
  12. }
  13. }
  14. return 0;
  15. }

输出结果为:8de1f0739c0e40b4a54e7826609be4cb.png

从输出结果来看,每一行内部的每个元素都是相邻的,地址之间相差4个字节,跨行位置处的两个元素,如:arr[0][4]和arr[1][0]之间也是差4个字节,所以二维数组中的每个元素都是连续存放的。

a18b45392a7a4b6f88f184b396c2bd28.png

了解清楚二维数组在内存中的布局,有利于后期使用指针来访问数组的学习。

 

 

 

 

 

 

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小蓝xlanll/article/detail/319676
推荐阅读
相关标签
  

闽ICP备14008679号