C语言数组入门新纪元:初学者的必备指南

一、数组概念

由相同数据类型的多个元素所组成的一种复合数据类型。

例如:int arr5

  • 语法释义:
    • arr是数组名,即这片连续内存的名称
    • 10 代表这片连续内存总共分成5个相等的格子,每个格子称为数组的元素
    • int 代表每个元素的类型,可以是任意基本类型,也可以是组合类型,甚至可以是数组
  • 初始化:在定义的时候赋值,称为初始化

二、数组格式

元素的数据类型 数组的名字元素的个数

例如:

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

int main()
{
   int arr[10];

   return 0;
}

如图,定义一个数组arr,该数组一共有十个元素,每个元素都是int类型。

三、数组特点

  • 数组中所有的元素数据类型都是一致的
  • 数组申请的内存是连续的。从低地址到高地址依次连续存放数组中的每个元素。

四、数组元素的引用

  • 存储模式:一片连续的内存,按数据类型分割成若干相同大小的格子
  • 元素下标:数组开头位置的偏移量,a0引用第1个格子,a1引用第2个格子,以此类推

五、数组的赋值

1、定义的时候初始化

赋值的时候,成员之间使用逗号隔开;赋值的成员的数据类型要与数组定义的数据类型一致

  • 初始化列表的时候,初始化的数据 个数小于或者等于长度例如:

例如:

cpp 复制代码
int arr[5] = {1,2,3,4,5};

int arr[] = {1,2,3,4,5};//语法正确,如果对全部数组元素赋初值,那可以不指定数组长度
  • 如果是定义的时候初始化,但是初始化列表个数小于数组的大小,那么无论这个数组是全局变量还是局部变量,没有赋值的成员都是为0

注意:int arr3 = {100,200,300,400};//错误,越界访问没有申请到的空间

2.先定义,没有初始化的话: 全局变量为0,局部变量为随机值

3、空数组

例如:

cpp 复制代码
int arr[5] = {0}; //表示给arr数组中第0个元素赋值为0,后面所有元素都会默认为0

4、测量数组大小和元素个数

  • 测量数组的总大小: sizeof(arr)
  • 测量数组的元素的个数:sizeof(arr)/sizeof(arr0)

例如:

这就是我对C语言数组初阶的理解啦!是不是觉得数组真是个实用又有趣的工具呢?如果你有任何疑问,或者想要分享更多关于数组的小技巧、经验,欢迎随言 哦!咱们一起交流学习,让编程之路越走越宽广!!!

相关推荐
zz34572981131 分钟前
C语言中字符串常量存储位置
c语言·开发语言·算法·青少年编程
noipp2 分钟前
推荐题目:洛谷 P16510 [GKS 2015 #C] gRanks
java·c语言·开发语言·c++·python·算法
程序喵大人3 分钟前
从内存/汇编角度看C与C++:指针、引用、对象的底层差异
c语言·汇编·c++·指针·引用·对象
8Qi816 分钟前
LeetCode 148. 排序链表 —— 解法二:自底向上归并(迭代,O(1) 空间)
数据结构·算法·leetcode·链表·归并·迭代
嘿黑嘿呦18 分钟前
数据结构-图论-最小生成树
数据结构·算法·图论
Swift社区1 小时前
OpenHarmony鸿蒙PC平台移植 gifsicle:CC++ 三方库适配实践(Lycium tpc_c_cplusplus)
c语言·c++·harmonyos
東隅已逝,桑榆非晚1 小时前
编译和链接
c语言·笔记
欧米欧1 小时前
C++进阶数据结构之红黑树
数据结构
papership2 小时前
【入门级-数据结构-1、线性结构:链 表(单链表、双向链表、循环链表 )】
数据结构·算法·链表
csdn_aspnet2 小时前
C++ 霍尔分区算法(Hoare‘s Partition Algorithm)
数据结构·c++·算法