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

一.数组的概念

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

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

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

2.1数组的创建

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

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

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

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

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

int  arr[20]

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

char ch[20];
float core[10];

2.2数组的初始化

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

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

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

int arr1[5]={
   0};

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

错误的初始化

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

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

2.3 数组的类型

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

比如

char arr1[20];
int arr2[30];

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};

在这里插入图片描述
在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;
}

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;
}

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

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;
}

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

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

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

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个字节)。所以:数组在内存中是连续存放的。

五. 二维数组的创建

5.1二维数组的概念

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

在这里插入图片描述

5.2如何创建二维数组

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

//如:
int arr_zy[3][7]
double arr_zy1[5][6]

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

六·.二维数组的初始化

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

6.1不完全初始化

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

在这里插入图片描述

6.2完全初始化

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

6.3按行初始化

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

在这里插入图片描述

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

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

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

七.二维数组的使用

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;
}

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

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

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

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;
}




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

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

#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. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-23 17:52:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-23 17:52:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-23 17:52:01       87 阅读
  4. Python语言-面向对象

    2024-02-23 17:52:01       96 阅读

热门阅读

  1. 通过SSH 可以访问Ubuntu Desktop吗?

    2024-02-23 17:52:01       46 阅读
  2. 排序算法:冒泡排序

    2024-02-23 17:52:01       44 阅读
  3. 快速了解eBay被封号的原因以及卖家申诉的方法!

    2024-02-23 17:52:01       136 阅读
  4. 【数据结构和算法】链表的简单实现

    2024-02-23 17:52:01       65 阅读
  5. Oracle 总结

    2024-02-23 17:52:01       63 阅读
  6. CSS:BFC

    CSS:BFC

    2024-02-23 17:52:01      48 阅读
  7. kafka 生产者消费者设计思考

    2024-02-23 17:52:01       54 阅读
  8. Vue学习之响应式基础

    2024-02-23 17:52:01       49 阅读