C++中的数组你真的理解了吗

 更新时间:2022年02月15日 15:53:31   作者:没有省略号  
这篇文章主要为大家详细介绍了C++的数组,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

1 概述

所谓数组,就是一个集合,里面存放了相同类型的数据元素。

特点1:数组中的每个数据元素都是相同的数据类型。

特点2:数组是由连续的内存位置组成的。

2 一维数组

2.1 一维数组定义方式

一共有三种

1.数据类型 数组名[数组长度];
2.数据类型 数组名[数组长度]={值1,值2,值3,...};
3.数据类型 数组名[]={值1,值2,值3,...};
#include<iostream>
using namespace std;
int main()
{	
	//第一种定义数组
	int arr[5] ;
	memset(arr, 0, sizeof(arr));//初始化为0,否则为随机数
	arr[0] = 10;
	arr[1] = 10;
	arr[2] = 10;
	arr[3] = 10;
	arr[4] = 10;
	//访问数组
	for (int i = 0; i < 5; i++) 
	{
		cout << arr[i] << " ";
	}
	cout << endl;
	//第二种定义数组
	//如果在初始化的时候没有填充完,剩余的会用0来填充。
	int brr[5] = { 20,20,20,20 };
	for (int i = 0; i < 5; i++)
	{
		cout << brr[i] << " ";
	}
	cout << endl;
	//第三种定义数组
	char crr[] = { '3','3','3','3','c'};
	for (int i = 0; i < 5; i++)
	{
		cout << crr[i] << " ";
	}
	system("pause");
	return 0;
}
  • 第一种方法是先声明再定义,对于全局/静态数组(定义在main()之外的数组),数组内容自动初始化为0。如果是局部的,此时数组的各元素是随机数,这时可以用 memset(arr, 0, sizeof(arr)); 使所有元素初始化为0;
  • 第二种方法是在定义的时候直接初始化,这时如果在初始化的时候没有填充完,剩余的会用0来填充。
  • 第三种方法在定义的时候不指定长度,这时会默认数组长度是你所赋的值的数量。

如果引用的索引超出了数组长度,也可以输出,输出结果是随机数(int型数组)/ 问号(char型)。

2.2 一维数组组名

一维数组组名用途:

  • 可以统计整个数组在内存中的长度。
  • 可以获取数组在内存中的首地址。

注意:数组名是常量,不可以像更改数组元素那样更改数组名

#include<iostream>
using namespace std;
int main()
{
	//1.统计内存
	int arr[5] = { 1,2,3,4,5 };
	cout << "整个数组占用内存空间为:" << sizeof(arr) << endl;
	cout << "每个元素占用内存空间为:" << sizeof(arr[0]) << endl; //元素内存相同,所以只看一个就可以了。
	//2.查看数组首地址
	cout << "数组的首地址为(十六进制):" << arr << endl;
	cout << "数组的首地址为(十进制):" << (int)arr << endl;
	cout << "数组的第一个元素地址为(十进制):" << (int)&arr[0] << endl;
	cout << "数组的第二个元素地址为(十进制):" << (int)&arr[1] << endl;
	//会发现差4个字节,就是一个整型数组的内存大小。
	//3.数组名是常量,不可以想更改数组元素那样更改数组名
	//arr=crr
	system("pause");
	return 0;
}

练习案例1

在这里插入图片描述

#include<iostream>
using namespace std;
int main()
{
	int arr[5] = { 300,350,200,400,250 };
	int size = sizeof(arr) / sizeof(arr[0]);
	int max = 0;
	for (int i = 0; i < size; i++)
	{
		if (arr[i] > max) { max = arr[i];}
	}
	cout << "最重的小猪体重为:" << max << endl;
	system("pause");
	return 0;
}

练习案例2

在这里插入图片描述

#include<iostream>
using namespace std;
int main()
{
	int arr[5] = { 1,3,5,9,4 };
	int size = sizeof(arr) / sizeof(arr[0]);
	int start = 0;
	int end = size - 1;
	int temp = 0;
	//打印逆置前的数组
	cout << "数组逆置前:" << endl;
	for (int i = 0; i < size; i++)
	{
		cout << arr[i] << " ";
	}
	//逆置
	while (start < end)
	{
		temp = arr[start];
		arr[start] = arr[end];
		arr[end] = temp;
		start++;
		end--;
	}
	//打印逆置后的数组
	cout << "数组逆置后:" << endl;
	for (int i = 0; i < size; i++)
	{
		cout << arr[i] << " ";
	}
	system("pause");
	return 0;
}

2.3 冒泡排序

作用:最常用的排序算法,对数组内元素进行排序。

方法

  • 比较相邻的元素。如果第一个比第二 个大, 就交换他们两个。
  • 对每一对相邻元素做同样的工作,执行完毕后,找到第一个最大值。
  • 重复以上的步骤,每次比较次数-1,直到不需要比较

例如:排序{4,2,8,0,5,7,1,3,9}

在这里插入图片描述

#include<iostream>
using namespace std;
int main()
{
	int arr[] = { 4,8,0,5,7,1,3,0};
	int size = sizeof(arr) / sizeof(arr[0]);
	//打印排序前的数组
	cout << "数组排序前:" << endl;
	for (int i = 0; i < size; i++)
	{
		cout << arr[i] << " ";
	}
	cout << endl;
	//冒泡排序
	for (int i = 0; i < size-1; i++)  //从0开始,共有size-1轮
	{
		for (int j = 0; j + i < size  - 1; j++) //每轮的比较次数与当前轮数相加小于size-1
		{
			if (arr[j] > arr[j + 1]) 
			{
				int temp = arr[j];
				arr[j] = arr[j+1];
				arr[j + 1] = temp;
			}
		}
	}
	cout << "数组排序后:" << endl;
	for (int i = 0; i < size; i++)
	{
		cout << arr[i] << " ";
	}
	cout << endl;

	system("pause");
	return 0;
}

3 二维数组

二维数组就是在一维数组上,多加一个维度。

3.1 二维数组定义方式

1.数据类型 数组名[行数][列数];
2.数据类型 数组名[行数][列数]={{数据1,数据2},{数据3,数据4}};
3.数据类型 数组名[行数][列数]={数据1,数据2,数据3,数据4};
4.数据类型 数组名[][列数]={数据1,数据2,数据3,数据4};

一般都是使用第二种,因为第二种最直观,提高代码的可读性。

#include<iostream>
using namespace std;
int main()
{	
	//1.数据类型 数组名[行数][列数];
	//2.数据类型 数组名[行数][列数] = { {数据1,数据2},{数据3,数据4} };
	//3.数据类型 数组名[行数][列数] = { 数据1,数据2,数据3,数据4 };
	//4.数据类型 数组名[][列数] = { 数据1,数据2,数据3,数据4 };
	//1.
	int arr[2][3];
	arr[0][0] = 0;
	arr[0][1] = 1;
	arr[0][2] = 2;
	arr[1][0] = 3;
	arr[1][1] = 4;
	arr[1][2] = 5;
	for (int i = 0; i < 2; i++) 
	{
		for (int j = 0; j < 3; j++) 
		{
			cout << arr[i][j] << "\t";
		}
		cout << endl;
	}
	cout << endl;
	//2.
	int brr[2][3] =
	{ 
		{1,2,3},
	    {4,5,6}
	};
	for (int i = 0; i < 2; i++)
	{
		for (int j = 0; j < 3; j++)
		{
			cout << brr[i][j] << "\t";
		}
		cout << endl;
	}
	cout << endl;
	//3.
	int crr[2][3] = { 1,2,3,4,5,6 };
	for (int i = 0; i < 2; i++)
	{
		for (int j = 0; j < 3; j++)
		{
			cout << crr[i][j] << "\t";
		}
		cout << endl;
	}
	cout << endl;
	//4.
	int drr[][3] = { 1,2,3,4,5,6 };
	for (int i = 0; i < 2; i++)
	{
		for (int j = 0; j < 3; j++)
		{
			cout << drr[i][j] << "\t";
		}
		cout << endl;
	}
	system("pause");
	return 0;
}

3.2 二维数组数组名

查看二维数组所占内存空间或者某行占用内存空间

#include<iostream>
using namespace std;
int main()
{
	int arr[2][3] =
	{
		{1,2,3},
		{4,5,6}
	};
	cout << "二维数组占用内存为:" << sizeof(arr) << endl;
	cout << "某一行占用内存为:" << sizeof(arr[0]) << endl;
	cout << "一个元素占用内存为:" << sizeof(arr[0][0]) << endl;
	int row = sizeof(arr) / sizeof(arr[0]);
	int column = sizeof(arr[0]) / sizeof(arr[0][0]);
	cout << "数组的行数为:" << row << "\n" << "数组的列数为:" << column << endl;
	cout << "二维数组的首地址是(16进制):" << arr << endl;
	cout << "二维数组的首地址是(10进制):" << (int)arr << endl;
	cout << "第一行首地址是(10进制):" << (int)arr[0] << endl;
	cout << "第二行首地址是(10进制):" << (int)arr[1] << endl;
	//会发现第一行和第二行差12,正好三个整型元素
	cout << "第二行第一个元素地址是(10进制):" << (int)&arr[1][0] << endl;//直接使用arr[1][0]是查看这个元素内容,需要用&取地址。
	system("pause");
	return 0;
}

3.3二维数组应用举例

在这里插入图片描述

#include<iostream>
using namespace std;
//vs快捷键crtl+d可以直接把本行复制到下行
int main()
{
	int arr[3][3] =
	{
		{100,100,100},
		{90 ,50 ,100},
		{60, 70 ,80 }
	};
	cout << "成绩情况为:" << endl;
	for (int i = 0; i < 3; i++) 
	{
		for (int j = 0; j < 3; j++) 
		{
			cout << arr[i][j] << " ";
		}
		cout << endl;
	}
	string names[3] = { "张三","李四","王五" };
	for (int i = 0; i < 3; i++)
	{
		int sum = 0;
		for (int j = 0; j < 3; j++)
		{
			sum += arr[i][j];
		}
		cout << names[i] << "的总成绩为:" << sum << endl;
	}
	system("pause");
	return 0;
}

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!   

相关文章

  • C语言中do-while语句的2种写法示例

    C语言中do-while语句的2种写法示例

    这篇文章主要给大家介绍了关于C语言中do-while语句的2种写法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • C++ ffmpeg实现将视频帧转换成jpg或png等图片

    C++ ffmpeg实现将视频帧转换成jpg或png等图片

    有时播放实时流的时候有截图的需求,需要将解码出来的图片保存本地或上传服务器,这时就需要将avframe中的数据编码成png、jpg等格式的图片,我们使用ffmpeg的相关编码器就可以实现功能,下面就来讲讲具体实现方法吧
    2023-03-03
  • C++实现LeetCode(169.求大多数)

    C++实现LeetCode(169.求大多数)

    这篇文章主要介绍了C++实现LeetCode(169.求大多数),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • 详解C++中future和promise的使用

    详解C++中future和promise的使用

    future和promise的作用是在不同线程之间传递数据,这篇文章主要为大家详细介绍了C++中future和promise的具体使用,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-05-05
  • 基于Qt OpenCV实现图像数据采集软件

    基于Qt OpenCV实现图像数据采集软件

    这篇文章主要为大家详细介绍了如何利用Qt+OpenCV实现图像数据采集软件,文中的示例代码讲解详细,对我学习或工作有一定参考价值,感兴趣的可以了解一下
    2022-07-07
  • 举例讲解C语言对归并排序算法的基础使用

    举例讲解C语言对归并排序算法的基础使用

    这篇文章主要介绍了C语言对归并排序算法的使用,归并排序算法的平均事件复杂度为(n\log n),需要的朋友可以参考下
    2016-05-05
  • 用C语言求解第N项斐波那契数列问题

    用C语言求解第N项斐波那契数列问题

    这篇文章主要介绍了用C语言求解第N项斐波那契数列问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C++ 组合 (Composition)的介绍与实例

    C++ 组合 (Composition)的介绍与实例

    这篇文章主要给大家介绍了关于C++ 组合(Composition)的相关资料,组合就是将对象组合成树形结构以表示“部分-整体”的层次结构,使得用户对单个对象和组合对象的使用具有一致性。需要的朋友可以参考下
    2021-05-05
  • 详解C语言中的动态内存管理

    详解C语言中的动态内存管理

    对于数据的存储我们可以静态存储,也可以动态存储,两种方式都有自己特有的好处,这篇文章教我们如和进行动态的数据存储!!!!感兴趣的小伙伴可以跟随小编一起学习一下
    2022-12-12
  • 用C++类实现单向链表的增删查和反转操作方法

    用C++类实现单向链表的增删查和反转操作方法

    下面小编就为大家带来一篇用C++类实现单向链表的增删查和反转操作方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04

最新评论