【C语言】数组概述

news/2024/10/22 14:28:48/

🚩纸上得来终觉浅, 绝知此事要躬行。
🌟主页:June-Frost
🚀专栏:C语言

🔥该篇将带你了解 一维数组,二维数组等相关知识。

目录:

  • 📘前言:
  • 🌟一维数组:
    • 创建
    • 初始化
    • 使用
    • 存储表现
  • 🌟二维数组:
    • 创建
    • 初始化
    • 使用
    • 存储表现
  • 🌟数组越界
  • 🌟数组名的含义
  • 🌟冒泡排序
  • ❤️ 结语

📘前言:

 C语言中,如果想存储一个整型,那么我们可以通过创建一个整型变量去存储一个数,如果想要存储一组相同类型的数,如果依次创建变量会显得很繁琐,C语言中提供了数组的概念,可以将一组相同类型的数据一次存储起来。 数组—— 一组相同类型元素的集合。


🌟一维数组:

创建

数组的创建方式:

例如:
int arr[10];
这个声明定义了一个arr数组,其中有10个元素,每个元素都是整型。
📙注意:

针对 const_n 有两种情况:

  • C99 标准中引入了变长数组的概念,使得数组在创建的时候可以使用变量,但是这样的数组不能初始化
    例如: gcc环境下,int n = 0; int arr[n];
  • C99 标准之前,数组的大小只能是常量表达式。例如:VS2022,VS2019等IIDE下,int arr[10];

初始化

初始化:在创建数组的同时给数组的内容一些合理初始值 。
初始化的一些方式:

  • 完全初始化:
    int arr[5] = { 1,2,3,4,5 };
  • 不完全初始化:
    int arr[5] = { 1,2,3 };剩余的元素都默认是 0.
    int arr[5] = { 0 };第一个元素被赋值0,其他元素默认为0,使得全部元素被赋0.
  • 省略数组大小:
    int arr[] = {1,2,3,4,5}; 省略数组的大小后,数组必须初始化,数组的元素个数根据初始化的内容来确定。
    char arr[] = "abc"; 4 个元素。
    char arr[] = { 'a','b','c' }; 3个元素
    char arr[] = { 97,'b','c' };数组内容与第二个一摸一样。

使用

数组下标是用来访问数组里每个元素的唯一标识符,每个数组的元素都有自己的下标,数组下标是从0开始,依次递增。

例如:

 想要访问数组元素,就需要使用操作符 [ ] (下标引用操作符),它其实就是数组访问的操作符。
 [ ] 有两个操作数,一个是数组名称,一个是下标,例如:想要访问第一个元素,只需要 arr[0] 即可。所以,我们很容易就可以拿到数组的每个元素。
例如:

#include<stdio.h>
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("%d ", arr[i]);}return 0;
}

存储表现

int arr[] = { 1,2,3};每个元素的地址打印一下:

可以发现每个元素地址的差为4,而一个地址管理一个字节,这意味着地址之前有4个字节,也就是1个整型。
如图:

通过观察地址,我们可以发现:数组在内存中是连续存放的。并且,随着数组下标的增长,元素的地址,也在有规律的递增。


🌟二维数组:

 二维数组是一种特殊的数组,它由一个或多个行和列组成,可以一次存储多组数据。

创建

基本形式:

例如:int arr[3][4] 创建了一个3行4列的数组,每个元素都是int。


初始化

初始化的一些方式:

  • 完全初始化:
    int arr[2][2] = { 1,2,3,4 };
    int arr[2][2] = { {1,2},{3,4} };
  • 不完全初始化:
    int arr[3][4] = { 1,2,3,4 };
    int arr[3][4] = { {1,2},{3,4} };
  • 省略行:
    int arr[][2] = { {1,2},{3,4} };
    int arr[][4] = {1,2,3,4,5};
    二维数组有初始化,行可以省略,列不可以省略。

使用

二维数组的使用同一维数组一样,通过下标访问元素。
int arr[3][4] = { {1,2,3,4},{3,4,5,6},{5,6,7,8} };


例如,访问整型8 ,arr[2][3] 即可。这样就可以遍历访问每一个元素。

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

存储表现

将上述例子的地址打印出来:

可以发现,二维数组在内存中也是连续存储的(从低地址到高地址)。所以我们可以将二维数组看作是一维数组的集合。


🌟数组越界

  • 数组的下标是有范围限制的。

  • 数组的下标规定是从0开始的,如果数组有n个元素,最后一个元素的下标就是n-1。所以数组的下标如果小于0,或者大于n-1,就是数组越界访问了,超出了数组合法空间的访问。

  • C语言本身是不做数组下标的越界检查,编译器也不一定报错,但是编译器不报错,并不意味着程序就是正确的


🌟数组名的含义


观察上图,可以发现数组名是首元素地址。

但是如果是&arr,则是取出了整个数组的地址,+1直接跳过了整个数组。不仅如此,在计算数组大小时sizeof(arr),这里的arr也是整个数组。
所以针对这些情况,有着如下结论:

  • sizeof(数组名),计算整个数组的大小,sizeof内部单独放一个数组名,数组名表示整个数组
  • &数组名,取出的是数组的地址。&数组名,数组名表示整个数组
  • 除上述两种情况外,通常数组名是数组首元素的地址。

🌟冒泡排序

要求:将一个整型数组的数据排列为升序。例如:将 9 8 7 6 5 4 3 2 1排列为 1 2 3 4 5 6 7 8 9 。

冒泡排序的核心思想为两两相邻的元素进行比较。每一趟冒泡排序使得一个数字到达最终应该出现的位置。

例如:第一趟冒泡排序,将9放到最大位置处。

 如果按照上面的例子,排列10个数就需要9趟冒泡排序。(排列n个数最差情况需要排列n-1次)。
 第一趟冒泡排序(将9归位)需要对比9次,第二趟冒泡排序(将8归位)需要对比8次,第七趟冒泡排序(将7归位)需要对比7次,依次类推。

代码如下:

#include<stdio.h>
void bubble_sort(int arr[10], int sz)
{int i = 0;for (i = 0; i < sz-1; i++){int flag = 1; //标记int j = 0;for (j = 0; j < sz - 1 - i; j++){if (arr[j] > arr[j + 1]){flag = 0;int temp = 0;temp = arr[j + 1];arr[j + 1] = arr[j];arr[j] = temp;}}if (flag == 1)//如果等于1表示数组数据已经有序{break;}}
}
int main()
{int arr[10] = { 9,8,7,6,5,4,3,2,1,0 };int sz = sizeof(arr) / sizeof(arr[0]);bubble_sort(arr,sz);int i = 0;for (i = 0; i < sz; i++){printf("%d ", arr[i]);}return 0;
}

flag变量的解释:

哪怕一开始有序或者过程中有序都不会停止进入循环,所以我们可以在每一趟冒泡循环开始前就定义一个标记,如果在两两比较中不存在交换,那么就证明该数组元素已然有序,这样就可以减少循环次数,优化代码。


❤️ 结语

文章到这里就结束了,如果对你有帮助,你的点赞将会是我的最大动力,如果大家有什么问题或者不同的见解,欢迎大家的留言~


http://www.ppmy.cn/news/1047049.html

相关文章

Spring高手之路13——BeanFactoryPostProcessor与BeanDefinitionRegistryPostProcessor解析

文章目录 1. BeanFactoryPostProcessor 概览1.1 解读 BeanFactoryPostProcessor1.2. 如何使用 BeanFactoryPostProcessor 2. BeanDefinitionRegistryPostProcessor 深入探究2.1 解读 BeanDefinitionRegistryPostProcessor2.2 BeanDefinitionRegistryPostProcessor 的执行时机2.…

HJ15 求int型正整数在内存中存储时1的个数 之十进制转二进制

描述 输入一个 int 型的正整数&#xff0c;计算出该 int 型数据在内存中存储时 1 的个数。 数据范围&#xff1a;保证在 32 位整型数字范围内 输入描述&#xff1a; 输入一个整数&#xff08;int类型&#xff09; 输出描述&#xff1a; 这个数转换成2进制后&#xff0c;输出…

操作系统——操作系统内存管理基础

文章目录 1.内存管理介绍2.常见的几种内存管理机制3.快表和多级页表快表多级页表总结 4.分页机制和分段机制的共同点和区别5.逻辑(虚拟)地址和物理地址6.CPU 寻址了解吗?为什么需要虚拟地址空间? 1.内存管理介绍 操作系统的内存管理主要是做什么&#xff1f; 操作系统的内存…

ATF(TF-A)安全通告 TFV-8 (CVE-2018-19440)

安全之安全(security)博客目录导读 ATF(TF-A)安全通告汇总 目录 一、ATF(TF-A)安全通告 TFV-8 (CVE-2018-19440) 二、CVE-2018-19440 一、ATF(TF-A)安全通告 TFV-8 (CVE-2018-19440) Title 不保存x0~x3寄存器可能会将信息从一个非安全世界的SMC client泄漏到另一个 CVE ID …

PaddleRS 1.0.0版本安装

PaddleRS 1.0.0版本安装 PaddleRS是百度飞桨、遥感科研院所及相关高校共同开发的基于飞桨的遥感影像智能解译开发套件&#xff0c; 支持图像分割、目标检测、场景分类、变化检测、图像复原等常见遥感任务。 PaddleRS致力于帮助遥感领域科研从业者快速完成算法的研发、验证和调…

七夕最强Python表白代码来了

点击上方Python小二&#xff0c;选择星标公众号 干货速达&#xff0c;不迷路 快到七夕了&#xff0c;大家都懂&#xff0c;这里不过多解释了&#xff0c;送大家几段节日专属Python代码。 玫瑰 毫无疑问&#xff0c;玫瑰一直都是七夕、520......这类节日的专属&#xff0c;带文字…

五分钟粗略了解Linux内核

1 操作系统是什么 用户使用的交互系统 Linux操作系统&#xff0c;Window操作系统 2 内核是什么 从技术上来看&#xff0c;内核其实是硬件和软件之间的连接层&#xff0c;我们也可以称之为中间层。 网卡&#xff0c; 磁盘&#xff0c; 内存&#xff0c;寄存器。。。。硬件设备…

MetaMask Mobile +Chrome DevTools 调试Web3应用教程

注&#xff1a;本教程来源网络&#xff0c;根据项目做的整理 写好了WEB3应用&#xff0c;在本地调试用得好好的&#xff0c;但是用钱包软件访问就报莫名的错&#xff0c;但是又不知道是什么原因&#xff0c;排查的过程非常浪费时间 。 因此在本地同一局域网进行调试就非常有必要…