首页 > 其他分享 >C语言知识大闯关之一维数组

C语言知识大闯关之一维数组

时间:2024-07-23 13:30:08浏览次数:19  
标签:10 arr 下标 int 元素 C语言 数组 闯关

引言

数组由数据类型相同的一系列的数据组成;

- 数组存放的是一个或多个数据,但是数组内元素的个数不能为零。
- 数组存放的元素类型是相同的。

数组分为一维数组和多维数组;本章我们讲解的是一位数组。

一维数组的创建和初始化

一维数组创建

C语言中,需要使用数组时,通过声明告诉编译器数组内含有多少个元素和这些元素的类型,编译器根据这些信息创建数组。普通变量可以使用的类型,数组都可以使用。

/*一些数组的声明*/
int main()
{
    int num[10]  //内含10个int类型元素的数组
    float can[35] //内含35个float类型的数组
    char ch[25]  //内含25个char类型的数组
}

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

一维数组创建的基本形式

type arr_name[常量值]
  • type 为数组中所包含的元素的类型,如int、char、float等。
  • arr_name 为数组的名字,可按需起名
  • [常量值] 中的常量值为数组中元素的个数,用来指定数组的大小,数组大小也根据实际情况需求指定

数组的初始化

有时候,数组在创建的时候,我们需要给定一些初始值,这就叫做数组的初始化

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

//完全初始化
int arr[3] = {1 , 2 , 3}

//不完全初始化
int arr[10] = {1 , 2 , 3 }

//错误的初始化 - 初始化项太多,超过了数组大小
int arr[3] = {1 , 2 , 3 , 4}

一维数组的类型

数组也是有类型的,一维数组的类型即为去掉组名留下的即为数组的类型。

    int num[10]  
    float can[35] 
    char ch[25]
- 数组num的类型是 int[10]
- 数组can的类型是 float[35]
- 数组ch的类型是 char[25]

一维数组的使用

在学习了一维数组的基本语法后,我们知道一维数组可以存放数据,以此对数据进行操作,那么我们如何使用一维数组呢?

数组下标

数组为其中的每个元素提供了下标,以便我们对数组中的数据进行处理。
如下一个数组

int arr[10] = {1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10}

数组元素和下标

如图,根据数组中存放元素的顺序,从0开始由小到大对于元素标记下标。

- 即如果有n个元素,从0开始,最后一个元素的下标是n-1

元素下标引用

在C语言的数组中提供了一个操作符 [ ] , 这个操作符叫做 下标引用操作符

有了下标引用操作符,我们就可以根据下标利用操作符轻松的访问到数组的元素了,比如我们要访问下标为6的元素就可以使用arr[6],想要访问下标为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[6]);
	printf("%d\n", arr[3]);
	return 0;
}

输出结果

在这里插入图片描述

数组元素的打印

接下来,我们如何访问整个数组的内容呢?
只要我们产生数组所有元素的下标就可以了。比如一个容纳是个元素的数组,我们用for循环产生0~9的下标,接下来用小标进行访问就行了。

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

输出结果
在这里插入图片描述

数组的输入

明白了数组的访问,我们当然也可以根据需求,自己给数组输入想要的数据。

#include<stdio.h>
int main()
{
	int arr[10] = { 0 };
	int i = 0;
	int a = 0;
	for (i = 0; i < 10; i++)
	{
		scanf("%d ", &a);
		arr[i] = a;
	}
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr[i]);
	}

	return 0;
}

输出结果

在这里插入图片描述

一维数组在内存中的存储

有了前面的哪些知识,我们可以基本掌握一维数组了,但是如果要深入了解数组,我们最好能够了解一维数组在内存中的存储;

在其中的代码 “ %p ”是指明的是地址

#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;
所以我们可以得出结论:数组在内存中是连续存放的

sizeof计算数组元素个数

在遍历数组的时候,我们经常想知道数组中的元素个数,那在C语言中是什么样的方法呢?
我们其实可以通过sizeof计算数组的大小

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

输出结果

在这里插入图片描述
用sizeof函数计算数据的单位是字节
我们又知道数组中所有的元素的类型是相同的,所以我们用 sizeof( ) 求得数组的总字节和单个元素的字节,二者的商即是元素的长度!

int main()
{
	int arr[10] = { 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	printf("%zd\n", sz);
	return 0;
}

输出结果

在这里插入图片描述
这里的输出结果为10 , 表示该数组中的元素个数为10个。
有了这种方法,以后我们的数组就不用写死了,可以随时用这种方法计算数组中元素的个数!

标签:10,arr,下标,int,元素,C语言,数组,闯关
From: https://blog.csdn.net/2401_82489659/article/details/140618508

相关文章

  • 数组基本概念
    1.什么是数组2.一维数组的创建和初始化3.一维数组的使用4.⼀维数组在内存中的存储5.sizeof计算数组元素个数6.⼆维数组的创建7.⼆维数组的初始化8.⼆维数组的使⽤9.⼆维数组在内存中的存储1.什么是数组数组是⼀组相同类型元素的集合1.数组中存放的是1个或者多个......
  • 初识C语言(第一讲常见的C语言概念)
    文章目录一.C语言是什么?二.为什么选择C语言三.编译器的选择四.VS项目和源文件、头文件介绍五.第一个C语言程序六.main函数七.printf和库函数八.关键字介绍九.字符和ASCLL编码十.字符串和\0十一.转义字符十二.语句和语句分类十三.注释是什么?为什么写注释?总结一.C语言......
  • C语言printf和scanf函数详解
    文章目录一、printf二、scanf一、printfprintf()的作⽤是将参数⽂本输出到屏幕。它名字⾥⾯的f代表format(格式化),表示可以定制输出⽂本的格式,并且它是一个库函数,要包含头文件<stdio.h>,具体包含方式如下:#include<stdio.h>printf最基本的用法:用双引号直接引起需要......
  • 嵌入式C语言之流程控制语句
    一、程序的执行顺序1、自上向下,自左向右执行二、流程控制语句作用1、控制程序的执行顺序--控制条件--执行内容三、流程控制语句的分类1、选择结构--2条2、循环结构--3条3、控制语句--4条四、选择结构1、if选择结构(1)如果小刚的考试成绩大于90分,给予奖励①......
  • Python面试题:使用NumPy进行高效数组运算
    NumPy是Python中进行高效数组运算的基础库。以下是一些示例,展示了如何使用NumPy进行高效的数组运算,包括创建数组、数组操作、数学运算以及一些高级操作。安装NumPy如果你还没有安装NumPy,可以通过以下命令进行安装:pipinstallnumpy示例代码1.创建数组import......
  • 如何构建一维数组的二维数组的特定 Python 结构?
    如何构建一维数组(即行向量)的二维数组的特定结构以满足特定我正在维护的遗留程序的结构?我可以在此结构中生成正确的内容all_measurements[:12]array([[0.,0.,0.,2.],[0.02,0.334,0.04,2.24],[0.04,0.668,0.08,2.48],...........
  • C语言的数据类型、变量、操作符、printf、scanf详解
    目录一、数据类型1.1、什么是数据类型1.2、数据类型有哪些(1)字符型(2)整型(3)浮点型(4)布尔型1.3、有符号signed和无符号unsigned1.4、sizeof操作符二、变量2.1、变量的创建2.2、变量的分类2.3、变量的初始化三、操作符3.1、算术操作符3.2、赋值操作符3.3、单目操作......
  • C语言-选择结构程序设计
    通过例题,强化选择结构程序的编程技术例:从键盘输入3个整数,找出并输出其中数值最大的那一个。如果其中有一个以上的最大数(两数相等的情况),也要表示出来。//知识点:注意各语句中if和else的配对关系和相应的缩进书写形式#include<stdio.h>intmain(){inta=0;intb=0;......
  • 2048小游戏【C语言版】单文件编写
    设计思路游戏地图和初始设置:使用一个4x4的二维数组map来表示游戏地图。初始时,所有位置的值均为0。score记录玩家得分,move_num记录移动次数。随机生成数字:在地图上随机选择一个空位置生成2或4。只有在地图发生变化时才会生成新数字。游戏菜单:使用m......
  • 数据结构——堆(C语言版)
    树    树的概念:        树(Tree)是一种抽象数据结构,它由节点(node)的集合组成,这些节点通过边相连,把节点集合按照逻辑顺序抽象成图像,看起来就像一个倒挂着的树,也就是说数据结构中的树是根成朝上,叶子朝下。        树形结构中,⼦树之间不能有交集,否则就不......