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

二维数组的存储方式

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

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

相关推荐
Eternity∞9 分钟前
基于Linux系统vim编译器情况下的C语言学习
linux·c语言·开发语言·学习·vim
_OP_CHEN1 小时前
【算法基础篇】(四十四)数论之欧拉定理与扩展欧拉定理深度解析:从降幂到超大规模幂运算
c++·算法·蓝桥杯·算法竞赛·欧拉定理·扩展欧拉定理·acm/icpc
liulilittle1 小时前
DeepWiki: OPENPPP2 工程价值
网络·c++·网络协议·ai·信息与通信·通信
星河耀银海1 小时前
C++面向对象编程:从基础到实战
开发语言·c++
HUST1 小时前
C语言第十一讲: 深入理解指针(1)
c语言·开发语言
Ccjf酷儿1 小时前
C++语言程序设计 (郑莉)第三章 函数
开发语言·c++
石去皿1 小时前
从本地知识库到“活”知识——RAG 落地全景指南
c++·python·大模型·rag
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——力扣 844 题:比较含退格的字符串
数据结构·c++·算法·力扣·结构与算法
SoveTingღ2 小时前
【C语言】什么是野指针?
c语言·指针·嵌入式软件
自然数e2 小时前
c++多线程【多线程常见使用以及几个多线程数据结构实现】
数据结构·c++·算法·多线程