标签: 数组
2018年04月12日 17:44:4481人阅读 评论(0) 收藏 举报
 分类:
C语言知识总结(4) 

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_41035588/article/details/79915673

 

目录(?)[+]

 

致读者:

在程序设计中,为了处理方便,把具有相同类型的若干变量按有序的形式组织起来。这些按序排列的同类数据元素的集合称为数组。在C语言中,数组属于构造数据类型。

数组:一组有序数据集合,且其中的元素都属于同一数据类型(type_t arr_name [const_n];),利用数组名和下表来唯一确定数组中的元素。

1.数组的创建和初始化

创建数组方式:

一维数组:

  1. type_t  arr_name [const_n];
  2. //type_t  是数组元素的类型
  3. //arr_name  是数组名
  4. //const_n 是数组元素的个数,用来指定数组的大小,即整形表达式。
  5. int arr[10] = {0};//创建一个一维整型数组,包括十个数组元素。

二维数组:

  1. type_t  arr_name [const_n][const_n];
  2. //type_t  是数组元素的类型
  3. //arr_name  是数组名
  4. //const_n 是数组元素的个数,用来指定数组的大小,即整形表达式。
  5. int arr[3][4] = {0};//创建一个二维整型数组,包括十个数组元素。

初始化数组方式:

普通方式:

  1. int arr[10] = {0,1,2,3,4,5,6,7,8,9};
  2. int arr[3][4] = {1,2,3,4,5,6,7,8,9,10,11,12};

函数方式<一维数组>:

  1. #include <stdio.h>
  2. void initarr(int arr[], int sz)
  3. {
  4. int i = 0;
  5. for (i=0; i<10; i++)
  6. {
  7. arr[i] = i;  //给数组初始化为i
  8. }
  9. }
  10. void printarr(int arr[], int sz)
  11. {
  12. int i = 0;
  13. for (i=0; i<10; i++)
  14. {
  15. printf("%d ", arr[i]);//打印数组
  16. }
  17. }
  18. int main()
  19. {
  20. int arr[10] = {0}; //创建整型数组arr,元素为10个
  21. initarr(arr, 10); //数组初始化函数
  22. printarr(arr, 10);//打印数组函数
  23. return 0;
  24. }

结果所示:

二维数组函数初始化方法同一维数组函数初始化。

2.数组的引用

数组的使用是通过数组元素的下标来对数组元素进行调用。

一维数组引用代码如下:

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

结果所示:

二维数组使用也是通过元素下标的方式,代码如下:

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int arr[3][4] = {0};
  5. int i = 0;
  6. int j = 0;
  7. for (i = 0; i < 3; i++)
  8. {
  9. for (j = 0; j < 4; j++)
  10. {
  11. arr[i][j] = i * 4 + j + 1;
  12. }
  13. }
  14. for (i = 0; i < 3; i++)
  15. {
  16. for (j = 0; j < 4; j++)
  17. {
  18. printf("%d ",arr[i][j]);
  19. }
  20. }
  21. return 0;
  22. }

结果所示:

3.数组在内存当中的存储:

一维数组:

  1. #include<stdio.h>
  2. int main()
  3. {
  4. int arr[10] = { 0 };
  5. int i = 0;
  6. for (i = 0; i < 10; i++)
  7. {
  8. arr[i] = i;  }
  9. for (i = 0; i < 10; i++)
  10. {
  11. printf("&arr[%d] = %p\n", i, &arr[i]);//打印数组每个元素的地址
  12. }
  13. return 0;
  14. }

结果所示:

二维数组:

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

结果所示:

综上分析:

无论是一维还是二维数组,都是随着数组元素下标的增加,数组元素在内存当中的地址也是递增的。
再看其在内存中的存储方向,都是由低地址到高地址。
由此,我们可推断出,数组元素在内存当中的存储是连续的,其存储方向为由低地址指向高地址。

4.数组的指针访问

一维数组的指针访问,创建代码如下:

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

结果所示:

综上:数组名所代表的是数组首元素的地址。

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

结果所示:

综上:

数组名所代表的是数组首元素的地址。
而数组名代替整个数组(即不作为指针常量)的时候只有两种情况:
1. sizeof(数组名)   2. &数组名
只有这两种情况下,数组名才代替整个数组。

二维数组指针访问同上。

5.数组作为函数参数

在面对大量数据的处理时,有时不仅仅是要创建数组,更要将数组作为函数的参数进行相应的运算。
参数等价:int arr[]  <==>int *arr;
  1. #include <stdio.h>
  2. int LenTh(int arr[])
  3. {
  4. int sz = sizeof(arr) / sizeof(arr[0]);
  5. return sz;
  6. }
  7. int main()
  8. {
  9. int arr[] = { 1, 3, 5, 7, 9, 2, 4, 6, 8, 0 };
  10. int ret = 0;
  11. ret =LenTh(arr);
  12. printf("%d\n", ret);
  13. return 0;
  14. }

结果所示:

综上:

数组在作为函数参数传参时,传过去的是数组的首元素的地址,而不是整个数组。
而首元素地址为4个字节,地址也为四个字字节(32位仪器中),因此求出sz为1,其输出为1。
数组作为可以包含大量数据的集合,可以有效的处理大批量的数据,因此应用相当广泛。

【C语言】数组知识点总结的更多相关文章

  1. 学Android开发,入门语言java知识点

    学Android开发,入门语言java知识点 Android是一种以Linux为基础的开源码操作系统,主要使用于便携设备,而linux是用c语言和少量汇编语言写成的,如果你想研究Android,就去学 ...

  2. JavaScript语言基础知识点图示(转)

    一位牛人归纳的JavaScript 语言基础知识点图示. 1.JavaScript 数据类型 2.JavaScript 变量 3.Javascript 运算符 4.JavaScript 数组 5.Ja ...

  3. JavaScript语言基础知识点图示

    原文:JavaScript语言基础知识点图示 一位牛人归纳的JavaScript 语言基础知识点图示. 1.JavaScript 数据类型 2.JavaScript 变量 3.Javascript 运 ...

  4. C语言数组:C语言数组定义、二维数组、动态数组、字符串数组

    1.C语言数组的概念 在<更加优美的C语言输出>一节中我们举了一个例子,是输出一个 4×4 的整数矩阵,代码如下: #include <stdio.h> #include &l ...

  5. C/C++编程笔记:C语言入门知识点(三),请收藏C语言最全笔记!

    今天我们继续来学习C语言的入门知识点,第一课:C/C++编程笔记:C语言入门知识点(二),请收藏C语言最全笔记! 21. 输入 & 输出 当我们提到输入时,这意味着要向程序填充一些数据.输入可 ...

  6. GO语言数组和切片实例详解

    本文实例讲述了GO语言数组和切片的用法.分享给大家供大家参考.具体分析如下: 一.数组 与其他大多数语言类似,Go语言的数组也是一个元素类型相同的定长的序列. (1)数组的创建. 数组有3种创建方式: ...

  7. C语言 数组 列优先 实现

    C语言数组结构列优先顺序存储的实现 (GCC编译). 从行优先转换为列优先存储方式, 与行优先相比, 不同之处在于改变了数组维界基址的先后顺序, 从而改变了映像函数常量基址. /** * @brief ...

  8. C语言 数组 行优先 实现

    C语言数组结构行优先顺序存储的实现 (GCC编译). /** * @brief C语言 数组 行优先 实现 * @author wid * @date 2013-11-02 * * @note 若代码 ...

  9. 不可或缺 Windows Native (5) - C 语言: 数组

    [源码下载] 不可或缺 Windows Native (5) - C 语言: 数组 作者:webabcd 介绍不可或缺 Windows Native 之 C 语言 数组 示例cArray.h #ifn ...

随机推荐

  1. php 加密解密算法 用于数据传输

    /** * 加密方法 * @param string $data 要加密的字符串 * @param string $key 加密密钥 * @param int $expire 过期时间 (单位:秒) ...

  2. ORACLE 12c RAC的常用管理命令

    ORACLE 12c RAC的常用管理命令 一.查询 1.RAC查询 1.1.查询节点 [grid@swnode1 ~]$ su - grid [grid@swnode1 ~]$ /u01/app/1 ...

  3. 二分优化lis和STL函数

    LIS:最长上升子序列: 这个题我们很显然会想到使用dp, 状态设计:dp[i]代表以a[i]结尾的LIS的长度 状态转移:dp[i]=max(dp[i], dp[j]+1) (0<=j< ...

  4. Developing Vert.x Modules with Gradle

    ========= https://www.techempower.com/benchmarks/#section=data-r12&hw=peak&test=json ======= ...

  5. 解析JavaScript中的sort()排序方法以及原理

    Array.sort()方法将数组中的元素进行排序,返回排序后的数组,默认是按照升序排序的.sort方法会调用数组中每一项的toString()方法,然后按照ascii编码进行排序,如果数组含有und ...

  6. {408} client block at 0x005D4D10, subtype 0, 64 bytes long.a CButton object at $005D4D10, 64 bytes long

    现象:mfc动态生成了很多控件,new的,退出时也delet了,但是还是出现了标题的错误 解决:在任何可以执行的地方加代码: CMFCVisualManager ::SetDefaultManager ...

  7. orm 复习

    day70 2018-05-14 1. 内容回顾 1. ORM 1. ORM常用字段和属性 1. AutoField(primary_key=True) 2. CharField(max_length ...

  8. CF 528D. Fuzzy Search NTT

    CF 528D. Fuzzy Search NTT 题目大意 给出文本串S和模式串T和k,S,T为DNA序列(只含ATGC).对于S中的每个位置\(i\),只要中[i-k,i+k]有一个位置匹配了字符 ...

  9. Uva12174 Shuffle(滑动窗口)

    $play[i]$表示以$i$这个点结束的连续$s$个播放记录是否是无重复的,这样最后只需要枚举可能的播放时间,然后检查对应的播放区间是否是单独的就可以了.特殊情况是,出现的所有播放记录无重复,且长度 ...

  10. highcharts数据标签显示在柱状图里面解决办法

    1.现象:当各项占比相同时,数据显示在柱状图里面 2.解决方法: 3.效果