第三站:C/C++基础-二维数组

二维数组的概念

一维数组本身是多个大小相同的内存块,从0开始逐渐递增所组成的在横向上的有序"组合",

二维数组就是很多个一维数组在纵向上的组合,每一个一维数组就是二维数组在纵向上的从0开始的逐渐递增的一个单位,(所以一维数组在二维数组的基础上,每一个内存块都是不能缺少的)

二维数组作为形参传递时,和一维数组数组是一样的,不是简单的值传递,传递的是数组本身的地址

二维数组的定义和初始化

定义:

二维数组在定义的时候必须指定列数,,行数的元素在有元素的情况下剩余元素会补充为0,列数决定这个二维数组的完整性

二维数组的定义和一维数组一样(注:二维数组作为全局变量进行声明的时候若没有赋初始值,则默认补充为零,但是作为局部变量定义没有赋初始值的时候则会是随机值)

复制代码
#include <iostream>
using namespace std;

void putoutArray(int a[3][4]) {
	for (int i = 0; i < 3; i++){
		for (int j = 0; j < 4; j++) {
			cout << a[i][j]<<" ";
		}
		cout << endl;
	}

}
//作为全局变量进行定义
int test3[3][4];
int main(void) {
    //作为局部变量定义
	int test4[3][4];
	cout << "作为全局变量时" << endl;
	putoutArray(test3);

	cout << "作为局部变量时" << endl;
	putoutArray(test4);
return 0;
}

初始化

在定义的时候初始化

int test1[3][4] = {

{1,2,3,4},

{5,6,7,8},

{9,10,11,12}

};

注:最外围括号内部的每个括号相当于初始化一行,括号中可以省略某些元素的初始化.会默认补充为0;

在定义的时候初始化从头开始依次补充后面的值

int test2[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 };

复制代码
#include <iostream>
using namespace std;

void putoutArray(int a[3][4]) {
	for (int i = 0; i < 3; i++){
		for (int j = 0; j < 4; j++) {
			cout << a[i][j]<<" ";
		}
		cout << endl;
	}

}

int main(void) {

	cout << "第一种初始化方式" << endl;
	//在定义的时候初始化
	int test1[3][4] = {
		{1,2,3,4},
		{5,6,7,8},
		{9,10,11,12}
	};
	putoutArray(test1);
	cout << "第二种初始化方式" << endl;
	//在定义的时候初始化从头开始依次补充后面的值
	int test2[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 };
	putoutArray(test2);

    return 0;
}

二维数组的存储方式

设置断点调试,可以看到二位数组中的所有元素在内存中的存储方式

根据数据可以看到二维数组和一维数组一样也是有序的存放在内存空间的

相关推荐
代码AC不AC39 分钟前
【C++】STL简介
c++·stl简介
unityのkiven1 小时前
C++中的虚表和虚表指针的原理和示例
开发语言·c++
火山灿火山1 小时前
【简单模拟实现list】
c++
芯眼1 小时前
STM32启动文件详解(重点)
java·开发语言·c++·stm32·单片机·mybatis
汉克老师3 小时前
GESP2025年3月认证C++二级( 第三部分编程题(1)等差矩阵)
c++·算法·矩阵·gesp二级·gesp2级
小刘要努力呀!4 小时前
嵌入式开发学习(第二阶段 C语言基础)
c语言·学习·算法
joker D8884 小时前
【C++】深入理解 unordered 容器、布隆过滤器与分布式一致性哈希
c++·分布式·哈希算法
草莓熊Lotso4 小时前
【C语言字符函数和字符串函数(一)】--字符分类函数,字符转换函数,strlen,strcpy,strcat函数的使用和模拟实现
c语言·开发语言·经验分享·笔记·其他
野曙5 小时前
快速选择算法:优化大数据中的 Top-K 问题
大数据·数据结构·c++·算法·第k小·第k大
小秋学嵌入式-不读研版5 小时前
C42-作业练习
c语言·开发语言·笔记