学懂C语言(十八):C语言中数组及其应用

目录

一、数组的概念

二、数组的声明、初始化及访问

1、声明

2、初始化

3、访问数组元素

三、数组的应用

[1. 存储和处理数据](#1. 存储和处理数据)

[2. 字符串处理](#2. 字符串处理)

[3. 多维数组](#3. 多维数组)

[4. 函数参数](#4. 函数参数)

5、注意事项


一、数组的概念

C语言中的数组是一种数据结构,用于存储一组相同类型的元素。数组在内存中占据一块连续的存储空间,每个元素通过索引(下标)来访问。数组在C语言中非常基础且重要,广泛应用于各种编程场景。

所有的数组都是由连续的内存位置组成。最低的地址对应第一个元素,最高的地址对应最后一个元素。

数组中的特定元素可以通过索引访问,第一个索引值为 0。

C 语言还允许我们使用指针来处理数组,这使得对数组的操作更加灵活和高效。

二、数组的声明、初始化及访问

1、声明

在 C 中要声明一个数组,需要指定元素的类型和数组的名称,以及数组的大小,如下所示:

复制代码
 type arrayName [ arraySize ];

这叫做一维数组。arraySize 必须是一个大于零的整数常量,type 可以是任意有效的 C 数据类型。例如下面声明一个包含5个整数的数组:

cpp 复制代码
int arr[5]; // 声明一个包含5个整数的数组
2、初始化

数组可以在声明时进行初始化,也可以在声明后通过赋值来初始化。

cpp 复制代码
int arr[5] = {1, 2, 3, 4, 5}; // 声明并初始化一个包含5个整数的数组
int arr[] = {1, 2, 3, 4, 5};  // 自动推断数组大小
3、访问数组元素

数组元素通过索引来访问,索引从0开始。

cpp 复制代码
int x = arr[0]; // 访问第一个元素
arr[1] = 10;    // 修改第二个元素

三、数组的应用

1. 存储和处理数据

数组常用于存储一组相关的数据,并对其进行处理。

cpp 复制代码
#include <stdio.h>

int main() {
    int numbers[5] = {1, 2, 3, 4, 5};
    int sum = 0;

    for (int i = 0; i < 5; i++) {
        sum += numbers[i];
    }

    printf("Sum: %d\n", sum);
    return 0;
}
2. 字符串处理

在C语言中,字符串实际上是以空字符('\0')结尾的字符数组。

cpp 复制代码
#include <stdio.h>

int main() {
    char str[] = "Hello, World!";
    printf("%s\n", str);
    return 0;
}
3. 多维数组

C语言支持多维数组,最常见的是二维数组,可以用来表示矩阵等数据结构。

cpp 复制代码
#include <stdio.h>

int main() {
    int matrix[3][3] = {
        {1, 2, 3},
        {4, 5, 6},
        {7, 8, 9}
    };

    for (int i = 0; i < 3; i++) {
        for (int j = 0; j < 3; j++) {
            printf("%d ", matrix[i][j]);
        }
        printf("\n");
    }

    return 0;
}
4. 函数参数

数组可以作为函数的参数传递。需要注意的是,数组名在作为参数传递时,实际上传递的是数组的首地址。

cpp 复制代码
#include <stdio.h>

void printArray(int arr[], int size) {
    for (int i = 0; i < size; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
}

int main() {
    int numbers[5] = {1, 2, 3, 4, 5};
    printArray(numbers, 5);
    return 0;
}
5、注意事项
  1. 数组越界:访问数组时必须确保索引在有效范围内,否则会导致未定义行为。

  2. 数组大小 :数组的大小在声明时确定,之后不能改变。如果需要动态大小的数组,可以考虑使用动态内存分配(如mallocfree)。

    cpp 复制代码
    #include <stdio.h>
    #include <stdlib.h>
    
    int main() {
        int size;
        printf("Enter the size of the array: ");
        scanf("%d", &size);
    
        int *arr = (int *)malloc(size * sizeof(int));
        if (arr == NULL) {
            printf("Memory allocation failed\n");
            return 1;
        }
    
        for (int i = 0; i < size; i++) {
            arr[i] = i + 1;
        }
    
        for (int i = 0; i < size; i++) {
            printf("%d ", arr[i]);
        }
        printf("\n");
    
        free(arr);
        return 0;
    }

    通过以上讲解,你应该对C语言中的数组及其应用有了更深入的了解。数组是C语言中非常基础且强大的工具,掌握好数组的使用对于编写高效、简洁的代码至关重要。

相关推荐
~yY…s<#>1 小时前
【刷题17】最小栈、栈的压入弹出、逆波兰表达式
c语言·数据结构·c++·算法·leetcode
EricWang13583 小时前
[OS] 项目三-2-proc.c: exit(int status)
服务器·c语言·前端
我是谁??3 小时前
C/C++使用AddressSanitizer检测内存错误
c语言·c++
希言JY4 小时前
C字符串 | 字符串处理函数 | 使用 | 原理 | 实现
c语言·开发语言
午言若4 小时前
C语言比较两个字符串是否相同
c语言
TeYiToKu6 小时前
笔记整理—linux驱动开发部分(9)framebuffer驱动框架
linux·c语言·arm开发·驱动开发·笔记·嵌入式硬件·arm
互联网打工人no16 小时前
每日一题——第一百二十四题
c语言
爱吃生蚝的于勒6 小时前
深入学习指针(5)!!!!!!!!!!!!!!!
c语言·开发语言·数据结构·学习·计算机网络·算法
羊小猪~~6 小时前
数据结构C语言描述2(图文结合)--有头单链表,无头单链表(两种方法),链表反转、有序链表构建、排序等操作,考研可看
c语言·数据结构·c++·考研·算法·链表·visual studio
洋2406 小时前
C语言常用标准库函数
c语言·开发语言