【C语言数组】创建、初始化、以及使用1

简介: 【C语言数组】创建、初始化、以及使用

前言

  1. 数组的概念

数组是⼀组相同类型元素的集合:

• 数组中存放的是一个或多个数据,但数组元素个数不能为0。

• 数组中存放的多个数据类型相同。

组分为一维数组和多维数组,多维数组一般常见的是二维数组。

一、⼀维数组

1.1 数组创建

⼀维数组创建的基本语法如下:

1 type arr_name[常量值];

存放在数组的值被称为数组的元素,数组在创建的时候可以指定数组的⼤⼩数组的元素类型。

• type 指定的是数组中存放数据的类型,可以是: charshortintfloat 等,也可以⾃定义的类型

 arr_name 指的是数组名的名字,这个名字根据实际情况,起的有意义就⾏。

[] 中的常量值是⽤来指定数组的⼤⼩的,这个数组的⼤⼩是根据实际的需求指定就⾏。

⽐如:我们现在想存储某个班级的20⼈的数学成绩,那我们就可以创建⼀个数组,如下:

1 int math[20];
• 1

当然我们也可以根据需要创建其他类型和⼤⼩的数组:

1 char ch[6];
2 double score[8];

1.2 数组的初始化

有时候,数组在创建时需要给定一些初始值,这称为初始化。

那么数组如何初始化呢?数组的初始化一般使用大括号,将数据放在大括号中。

举个例子,你就明白啦:

1 //完全初始化
2 int arr[5] = {1,2,3,4,5};
3 
4 //不完全初始化
5 int arr2[6] = {1};//第⼀个元素初始化为1,剩6 余的元素默认初始化为0
7 
8 //错误的初始化 - 初始化项太多
9 int arr3[3] = {1, 2, 3, 4};//会导致数组越界,产生bug

1.3 数组的类型

数组也是有类型的,数组算是⼀种⾃定义类型,去掉数组名留下的就是数组的类型。

1 int arr1[10];
2 int arr2[12];
3 char ch[5];
• 1
• 2
• 3

arr1数组的类型是 int [10

arr2数组的类型是 int[12]

ch 数组的类型是 char [5]

二、 ⼀维数组的使⽤

学习了⼀维数组的基本语法,⼀维数组可以存放数据,存放数据的⽬的是对数据的操作,那我们如何使⽤⼀维数组呢?

2.1 数组下标

C语⾔规定数组是有下标的,下标是从0开始的,假设数组有n个元素,最后⼀个元素的下标是n-1,下标就相当于数组元素的编号,如下:

在C语⾔中数组的访问提供了⼀个操作符 [] ,这个操作符叫:下标引⽤操作符

有了下标访问操作符,我们就可以轻松的访问到数组的元素了,⽐如我们访问下标为7的元素,我们就可以使⽤ arr[7] ,想要访问下标是3 的元素,就可以使⽤ arr[3] ,如下代码:

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

输出:

2.2 数组元素的打印

接下来,如果想要访问整个数组的内容,应该怎么办呢?只需使用for循环产生0~9的下标,然后利用下标访问数组中的元素即可。具体代码如下:

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

2.3 数组的输⼊

       明⽩了数组的访问,当然我们也根据需求,不能只是给大括号简单的放几个值,所以我们可以给数组输⼊自己想要的数据,那我们怎么实现的呢? 如下:

#include <stdio.h>
int main()
{
    int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
    int i = 0;
    printf("请输入\n");
    for (i = 0; i < 10; i++)
    {
        scanf("%d", &arr[i]);
    }
    printf("输出\n");
    for (i = 0; i < 10; i++)
    {
        printf("%d ", arr[i]);
    }
    return 0;
}

输入和输出:

2.4 ⼀维数组在内存中的存储

有了前面的知识,我们实际上使用数组基本没有什么障碍了。如果我们要深入了解数组,最好能了解一下数组在内存中的存储

#include <stdio.h>
int main()
{
 int arr[10] = {1,2,3,4,5,6,7,8,9,10}; 
 int i = 0;
 for(i=0; i<10; i++)
 {
  printf("&arr[%d] = %p\n", i, &arr[i]);
 //使用&取地址符号,打印数组的存储地址
 }
 return 0;
}

从输出的结果我们分析,数组随着下标的增⻓,地址是由⼩到⼤变化的,并且我们发现每两个相邻的

元素之间相差4因为⼀个整型是4个字节)。所以我们得出结论:数组在内存中是连续存放的。在指针访问数组我会继续讲解,避免文章篇幅过长。

三、sizeof计算数组元素个数

在遍历数组的时候,我们经常想知道数组的元素个数,那C语⾔中有办法使⽤程序计算数组元素个数吗?

答案是有的,可以使⽤sizeof。

sizeof 中C语⾔是⼀个关键字,是可以计算类型或者变量⼤⼩的,其实 sizeof 也可以计算数组的⼤⼩。

⽐如:

#include <stido.h>
int main()
{
  int arr[10] = {0};
  printf("%d\n", sizeof(arr));
  return 0;
}

这⾥输出的结果是40,计算的是数组所占内存空间的总⼤⼩,单位是字节。


我们⼜知道数组中所有元素的类型都是相同的,那只要计算出⼀个元素所占字节的个数,数组的元素个数就能算出来。这⾥我们选择第⼀个元素算⼤⼩就可以。


#include <stido.h>
int main()
{
  int arr[10] = {0};
  printf("%d\n", sizeof(arr[0]));//计算⼀个元素的⼤⼩,单位是字节
  return 0;
}

计算⼀个元素的⼤⼩,单位是字节

接下来就能计算出数组的元素个数:


#include <stido.h>
int main()
{
  int arr[10] = {0};
  int sz = sizeof(arr)/sizeof(arr[0]);//40/4=10
  printf("%d\n", sz);
  return 0;
}

这⾥的结果是:10,表示数组有10个元素。

以后在代码中需要数组元素个数的地⽅就不⽤固定写死了,使⽤上⾯的计算,不管数组怎么变化,计算出的⼤⼩也就随着变化了。

【C语言数组】创建、初始化、以及使用2:https://developer.aliyun.com/article/1474231

相关文章
|
2月前
|
存储 C语言 C++
【C语言数组】
【C语言数组】
|
23天前
|
存储 编译器 C语言
【C语言基础考研向】09 一维数组
数组是一种有序集合,用于存储相同类型的数据,便于统一操作与管理。例如,将衣柜底层划分为10个格子存放鞋子,便于快速定位。在C语言中,数组定义格式为 `类型说明符数组名[常量表达式];`,如 `int a[10];` 表示定义了一个包含10个整数的数组。数组初始化时可以直接赋值,也可以部分赋值,且数组长度必须固定。数组在内存中连续存储,访问时需注意下标范围,避免越界导致数据异常。数组作为参数传递时,传递的是首地址,修改会影响原数组。
|
23天前
|
存储 C语言
【C语言基础考研向】10 字符数组初始化及传递和scanf 读取字符串
本文介绍了C语言中字符数组的初始化方法及其在函数间传递的注意事项。字符数组初始化有两种方式:逐个字符赋值或整体初始化字符串。实际工作中常用后者,如`char c[10]=&quot;hello&quot;`。示例代码展示了如何初始化及传递字符数组,并解释了为何未正确添加结束符`\0`会导致乱码。此外,还讨论了`scanf`函数读取字符串时忽略空格和回车的特点。
|
26天前
|
存储 算法 C语言
数据结构基础详解(C语言):单链表_定义_初始化_插入_删除_查找_建立操作_纯c语言代码注释讲解
本文详细介绍了单链表的理论知识,涵盖单链表的定义、优点与缺点,并通过示例代码讲解了单链表的初始化、插入、删除、查找等核心操作。文中还具体分析了按位序插入、指定节点前后插入、按位序删除及按值查找等算法实现,并提供了尾插法和头插法建立单链表的方法,帮助读者深入理解单链表的基本原理与应用技巧。
|
26天前
|
存储 人工智能 C语言
C语言程序设计核心详解 第六章 数组_一维数组_二维数组_字符数组详解
本章介绍了C语言中的数组概念及应用。数组是一种存储同一类型数据的线性结构,通过下标访问元素。一维数组定义需指定长度,如`int a[10]`,并遵循命名规则。数组元素初始化可使用 `{}`,多余初值补0,少则随机。二维数组扩展了维度,定义形式为`int a[3][4]`,按行优先顺序存储。字符数组用于存储字符串,初始化时需添加结束符`\0`。此外,介绍了字符串处理函数,如`strcat()`、`strcpy()`、`strcmp()` 和 `strlen()`,用于拼接、复制、比较和计算字符串长度。
|
2月前
|
算法 C语言
C语言------数组
这篇文章是关于C语言数组的实训,包括一维数组、二维数组和字符数组的定义、赋值、输入、输出方法,并通过实例代码演示了数组的使用和一些基本算法,如冒泡排序。
C语言------数组
|
2月前
|
存储 编译器 程序员
七:《初学C语言》— 数组
【8月更文挑战第2天】本篇文章详细讲解了一维数组和二维数组的创建、使用和初始化及如何使用sizeof()计算数组中的元素个数。并附带了多个教学源码及代码练习
44 1
七:《初学C语言》— 数组
|
2月前
|
存储 编译器 数据处理
【编程秘籍】解锁C语言数组的奥秘:从零开始,深入浅出,带你领略数组的魅力与实战技巧!
【8月更文挑战第22天】数组是C语言中存储同类型元素的基本结构。本文从定义出发,详述数组声明、初始化与访问。示例展示如何声明如`int numbers[5];`的数组,并通过下标访问元素。初始化可在声明时进行,如`int numbers[] = {1,2,3,4,5};`,编译器自动计算大小。初始化时未指定的元素默认为0。通过循环可遍历数组,数组名视为指向首元素的指针,方便传递给函数。多维数组表示矩阵,如`int matrix[3][4];`。动态数组利用`malloc()`分配内存,需用`free()`释放以避免内存泄漏。掌握这些技巧是高效数据处理的基础。
56 2
|
2月前
|
存储 编译器 C语言
C语言——数组
C语言——数组
|
2月前
|
存储 C语言
C语言(数组)
C语言(数组)
36 6
下一篇
无影云桌面