当前位置:   article > 正文

c语言---数组(超级详细)

c语言---数组(超级详细)

一.数组的概念

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

1.数组中存放的是1个或者多个数据,但是数组元素个数不能为0。
2.数组中存放的多个数据,类型是相同的。

二. 一维数组的创建和初始化

2.1数组的创建

type arr_x[n]//n是数组元素个数
  • 1

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

上述代码中的type指的是数组中存放的数据类型,数据类型可以是char, short,int等等…

arr_x指的是数组名的名字
[]是下标引用操作符

比如:有20个整型元素,存放在数组中,此时可以创建一个一维数组:

int  arr[20]
  • 1

当然其他类型也可以,比如:

char ch[20];
float core[10];
  • 1
  • 2

2.2数组的初始化

如何对数组进行初始化呢,下面就来解释

int arr[5]={1,2,3,4,5};
  • 1

上述代码就是数组的完全初始化

int arr1[5]={0};
  • 1

上述代码就是数组的不完全初始化,也就是第一个元素为1,其余未初始化的数据,默认就是0

错误的初始化

int a[2]={0,1,23,4,5};
  • 1

上述代码会报错,因为设置的初始值太多

2.3 数组的类型

数组也是具有类型的,数组也算是一种自定义类型,把数组名去掉剩下的就是数组类型

比如

char arr1[20];
int arr2[30];
  • 1
  • 2

arr1数组的类型就是char [20]
arr2数组的类型就是 int [30]

三. 一维数组的使用

3.1数组的下标

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

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

在这里插入图片描述
在C语⾔中数组的访问提供了⼀个操作符[] ,这个操作符叫:下标引用操作符

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;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

3.2数组元素的打印

这里我们直接访问数组下标就可以实现数组打印

#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;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

下面是运行结果
在这里插入图片描述

3.2数组元素的输入

这里我们用for‘循环来实现数组的输入


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

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

下面是运行结果
在这里插入图片描述

四. 一维数组在内存中的存储

下面一段代码,将打印数组的地址

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;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

下面是运算结果:
在这里插入图片描述

从输出的结果来看,数组随着下标的增⻓,地址是由小到大变化的,并且我们发现每两个相邻的元素之间相差4(因为⼀个整型是4个字节)。所以:数组在内存中是连续存放的。

五. 二维数组的创建

5.1二维数组的概念

如果我们把⼀维数组做为数组的元素,这时候就是⼆维数组,⼆维数组作为数组元素的数组被称为三维数组,⼆维数组以上的数组统称为多维数组。

在这里插入图片描述

5.2如何创建二维数组

type   arr_zy[n][n]//n是常量

//如:
int arr_zy[3][7]
double arr_zy1[5][6]
  • 1
  • 2
  • 3
  • 4
  • 5

解释上述代码中的信息:
3代表三行
7代表每行有7个元素
int表示数组的每个元素都是整型
arr_zy数组名,可以自定义

六·.二维数组的初始化

在创建变量或者数组的时候,给定⼀些初始值,被称为初始化。

6.1不完全初始化

int arr_zy[2][4]={123}double arr_zy1[3][6]={652}
  • 1
  • 2

在这里插入图片描述

6.2完全初始化

int arr3[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};
  • 1

6.3按行初始化

int arr4[3][5] = {{1,2},{3,4},{5,6}};
  • 1

在这里插入图片描述

6.4 初始化时省略行,但是不能省略列

int arr6[][5] = {1,2,3,4,5,6,7};
int arr7[][5] = {{1,2}, {3,4}, {5,6}};
  • 1
  • 2

在这里插入图片描述
在这里插入图片描述

七.二维数组的使用

7.1 二维数组的输入和输出

我们只要能够按照⼀定的规律产⽣所有的⾏和列的数字就行;以上⼀段代码中的arr数组为例,行的选择范围是0~ 2,列的取值范围是0~4,所以我们可以借助循环实现⽣成所有的下标

int main()
{
	int arr[3][5] = { 1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7 };
	int i = 0;//遍历⾏
	//输⼊
	for (i = 0; i < 3; i++) //产⽣⾏号
	{
		int j = 0;
		for (j = 0; j < 5; j++) //产⽣列号
		{
			scanf("%d", &arr[i][j]); //输⼊数据
		}
	}
	//输出
	for (i = 0; i < 3; i++) //产⽣⾏号
	{
		int j = 0;
		for (j = 0; j < 5; j++) //产⽣列号
		{
			printf("%d ", arr[i][j]); //输出数据
		}
		printf("\n");
	}
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25

下面是运行结果:
在这里插入图片描述

八. 二维数组在内存中的存储

可以打印出数组所有元素的地址的。代码如下:

int main()
{
	int arr[3][5] = { 0 };
	int i = 0;
	int j = 0;
	for (i = 0; i < 3; i++)
	{
		for (j = 0; j < 5; j++)
		{
			printf("&arr[%d][%d] = %p\n", i, j, &arr[i][j]);
		}
	}
	return 0;
}




  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

运行结果如下:
在这里插入图片描述

最后还有一个题目就是多个字符从两端移动,向中间汇聚

#include<string.h>
#include<time.h>
#include<stdio.h>
#include<Windows.h>
int main()
{
	char arr1[] = "welcome to zy space";
	char arr2[] = "#######################";
	int left = 0;
	int right = strlen(arr1) - 1;
	printf("%s\n", arr2);
	while (left <= right)
	{
		Sleep(1000);
		arr2[left] = arr1[left];
		arr2[right] = arr1[right];
		left++;
		right--;
		printf("%s\n", arr2);
	}
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22

运行结果:
在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/142950?site
推荐阅读
相关标签
  

闽ICP备14008679号