第三站: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;
}

二维数组的存储方式

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

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

相关推荐
FL162386312926 分钟前
[ubuntu][C++]onnxruntime安装cpu版本后测试代码
linux·c++·ubuntu
JuneXcy42 分钟前
结构体简介
c语言·数据结构·算法
要做朋鱼燕42 分钟前
【C++】 priority_queue 容器模拟实现解析
开发语言·c++·笔记·职场和发展
jiaway1 小时前
【C语言】第四课 指针与内存管理
c语言·开发语言·算法
励志不掉头发的内向程序员1 小时前
C++进阶——继承 (1)
开发语言·c++·学习
黑客思维者3 小时前
《我是如何用C语言写工控系统的漏洞和Bug》连载(1)内容大纲
c语言·bug·工控漏洞
mit6.8243 小时前
并查集|栈
c++
中国胖子风清扬3 小时前
Rust 序列化技术全解析:从基础到实战
开发语言·c++·spring boot·vscode·后端·中间件·rust
j_xxx404_3 小时前
数据结构:栈和队列力扣算法题
c语言·数据结构·算法·leetcode·链表
南莺莺3 小时前
假设一个算术表达式中包含圆括号、方括号和花括号3种类型的括号,编写一个算法来判别,表达式中的括号是否配对,以字符“\0“作为算术表达式的结束符
c语言·数据结构·算法·