小朋友学C语言(20):数组

傷城~ 2022-06-07 12:52 289阅读 0赞

一、数组简介

C 语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据,但它往往被认为是一系列相同类型的变量。
数组的声明并不是声明一个个单独的变量,比如 number0、number1、…、number99,而是声明一个数组变量,比如 numbers,然后使用 numbers[0]、numbers[1]、…、numbers[99] 来代表一个个单独的变量。数组中的特定元素可以通过索引访问。
所有的数组都是由连续的内存位置组成。最低的地址对应第一个元素,最高的地址对应最后一个元素。

array.jpg

二、动手编写一个简单的数组程序

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

运行结果:

  1. a[0] = 2
  2. a[1] = 4
  3. a[2] = 5
  4. a[3] = 8
  5. a[4] = 20

分析:
(1)int a[5]; 这是声明了一个数组,数组类型为整型,数组名为a,数组大小为5,表示可以放5个整型元素。

(2)a[5] = {2, 4, 5, 8, 20},这是赋值语句,类比于a = 1。不过通常说成是数组的初始化,而不是给数组赋值。注意,是用大括号把元素包含在内,而不是中括号或小括号。

(3)数组的下标是从0开始的,所以本程序中的五个元素为a[0], a[1], a[2], a[3], a[4],而不是a[1], a[2], a[3], a[4], a[5]。这从for循环也可以看出,for循环是从0增加到4,而不是从1增加到5。如果要获取a[5]或a[6],编译器会报数组越界的错误或者直接取到了0!。

(4)假如数组的大小为size,那么元素的最大下标为size - 1。以本程序为例,大小为5,则最大下标为4,即只能取到a[4]。

(5)如果把在数组声明后直接初始化,类似本程序这样的,可以不用写数组大小,运行效果完全一样。

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

三、逐个给数组元素赋值

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

运行结果:

  1. a[0] = 0
  2. a[1] = 2
  3. a[2] = 4
  4. a[3] = 6
  5. a[4] = 8

注意,在声明数组int a[5]的时候,因为不是立即初始化(跟上面的例子不一样),则数组大小(这里为5),不能省略。

四、浮点数数组

  1. #include <stdio.h>
  2. int main()
  3. {
  4. float a[4] = {
  5. 1.1, 2.2, 3.33, 5.555};
  6. for(int i = 0; i <= 3; i++)
  7. {
  8. printf("a[%d] = %f\n", i, a[i]);
  9. }
  10. return 0;
  11. }

运行结果:

  1. a[0] = 1.100000
  2. a[1] = 2.200000
  3. a[2] = 3.330000
  4. a[3] = 5.555000

五、字符数组

  1. #include <stdio.h>
  2. int main()
  3. {
  4. char c[] = {
  5. 'H', 'e', 'l', 'l', 'o', '!'};
  6. for(int i = 0; i < 6; i++)
  7. {
  8. printf("%c", c[i]);
  9. }
  10. return 0;
  11. }

运行结果:

  1. Hello!

六、如果没有显示写出数组长度,求数组长度

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int a[] = {
  5. 2, 4, 5, 8 ,20};
  6. printf("Size of int: %ld\n", sizeof(int));
  7. printf("Length of a: %ld\n", sizeof(a));
  8. printf("Size of a: %ld\n", sizeof(a) / sizeof(int));
  9. printf("====================\n");
  10. float b[] = {
  11. 2.0, 3.2, 5.13, 8.8888,20};
  12. printf("Size of float: %ld\n", sizeof(float));
  13. printf("Length of b: %ld\n", sizeof(b));
  14. printf("Size of b: %ld\n", sizeof(b) / sizeof(float));
  15. printf("====================\n");
  16. double d[] = {
  17. 2.0, 3.2, 5.13, 8.8888,20};
  18. printf("Size of double: %ld\n", sizeof(double));
  19. printf("Length of d: %ld\n", sizeof(d));
  20. printf("Size of d: %ld\n", sizeof(d) / sizeof(double));
  21. printf("====================\n");
  22. char c[] = {
  23. 'H', 'e', 'l', 'l', 'o', '!'};
  24. printf("Size of char: %ld\n", sizeof(char));
  25. printf("Length of c: %ld\n", sizeof(c));
  26. int size = sizeof(c) / sizeof(char);
  27. printf("Size of c: %d\n", size);
  28. for(int i = 0; i < size; i++)
  29. {
  30. printf("%c", c[i]);
  31. }
  32. return 0;
  33. }

运行结果:

  1. Size of int: 4
  2. Length of a: 20
  3. Size of a: 5 ====================
  4. Size of float: 4
  5. Length of b: 20
  6. Size of b: 5 ====================
  7. Size of double: 8
  8. Length of d: 40
  9. Size of d: 5 ====================
  10. Size of char: 1
  11. Length of c: 6
  12. Size of c: 6
  13. Hello!

分析:
以int a[] = {2, 4, 5, 8 ,20}; 为例:
整型数每个占4字节,所以sizeof(int) = 4字节
数组a包含了5个整型数,计算出a的长度(即有多少个字节)sizeof(a) = 20字节
相除即得到a的大小(即个数)为sizeof(a) / sizeof(int) = 5个元素

七、作业

(1)断点调试第六部分中的程序
(2)默写第六部分中的程序

更多内容请关注微信公众号
wchat\_official.jpg

发表评论

表情:
评论列表 (有 0 条评论,289人围观)

还没有评论,来说两句吧...

相关阅读

    相关 小朋友C语言20):数组

    一、数组简介 C 语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据,但它往往被认为是一系列相同类型的变量。 数组的声明并