当前位置: 首页 > news >正文

第12课 二维数组(1)

string类型不知道各位童鞋们都掌握了没,没掌握的话,嘿嘿嘿(抱拳)我稍微练过一点散打哦。

好了,开玩笑的,今天的课程难度较高,所以我决定分三课讲,就是想让大家把二维数组彻底吃透,以便于学习后面的三维,四维数组。好了,废话不多说,说多了也是废话,废话就是废话,还是不要说废话了。正片开始!

1.二维数组是什么

在C++中,二维数组是一种数据结构,用于存储相同类型的元素,这些元素被组织成行和列的形式。二维数组可以被看作是数组的数组,即数组中的每个元素本身也是一个数组。这使得二维数组非常适合表示表格数据或矩阵。

例如,声明一个包含3行4列的整数二维数组可以写成:

int myArray[3][4];

在C++中,二维数组的内存是连续分配的。这意味着数组的行是顺序存储在内存中的,每个行的元素也是连续存储的。

二维数组可以通过行和列的索引来访问其元素,例如 myArray[i][j],其中 i 是行索引,j 是列索引。索引从0开始,所以第一个元素的索引是 myArray[0][0]

二维数组的初始化也可以在声明时完成,例如:

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

这个例子中,myArray 被初始化为一个3行4列的数组,每个元素被赋予了相应的值。

在这里说一下,在编程语言中,声明(Declaration)是指创建变量或对象的语句,它告诉编译器变量的名称、数据类型以及它将要存储的内存位置。声明变量是编程中的一个基本操作,它为程序中使用的数据分配空间。

在C++中,声明通常包括以下几个部分:

  1. 数据类型(Type):这是变量将要存储的数据的类型,比如 int 表示整数,float 表示浮点数,char 表示字符等。

  2. 变量名(Identifier):这是你给变量起的名字,用于在程序中引用该变量。变量名必须遵守C++的命名规则,比如不能以数字开头,不能包含空格,不能使用C++的保留字等。

  3. 可选的初始化(Optional Initialization):在声明变量的同时,你可以给它一个初始值。
    例如,以下是一个简单的变量声明:(其实跟定义一样)

    int number;  // 声明一个名为 'number' 的整数变量

    如果你在声明变量的同时给它一个初始值,这被称为初始化:

    int number = 10;  // 声明并初始化一个名为 'number' 的整数变量,初始值为 10

    对于数组,声明会指定数组中元素的类型和数组的大小:

    int myArray[10];  // 声明一个名为 'myArray' 的整数数组,包含10个整数

    对于二维数组,声明会指定数组中元素的类型以及行数和列数:

    int myMatrix[3][4];  // 声明一个名为 'myMatrix' 的二维整数数组,3行4列

    在这个例子中,int 是数据类型,myMatrix 是变量名,[3] 表示数组有3行,[4] 表示每行有4列。

    声明是告诉编译器你需要多少内存以及如何解释这块内存的第一步。在C++中,变量必须在使用之前声明。

    例题:
     

    题目描述

    输入两个nn行mm列的矩阵AA和BB,输出它们的和A+BA+B。

    输入格式

    第一行包含两个整数n和m,表示矩阵的行数和列数。1≤n≤100,1≤m≤1001≤n≤100,1≤m≤100。 接下来n行,每行m个整数,表示矩阵A的元素。 接下来n行,每行m个整数,表示矩阵B的元素。 相邻两个整数之间用单个空格隔开,每个元素均在1~1000之间。

    输出格式

    n行,每行m个整数,表示矩阵加法的结果。相邻两个整数之间用单个空格隔开。

    样例输入/输出

    输入数据 1

    3 3
    1 2 3
    1 2 3
    1 2 3
    1 2 3
    4 5 6
    7 8 9
    
     

    输出数据 1

    2 4 6
    5 7 9
    8 10 12

代码:(新手级)

#include<bits/stdc++.h>
using namespace std;
long long x,y,a[105][105],b[105][105];
int main(){cin>>x>>y;for(int i=1;i<=x;i++){for(int j=1;j<=y;j++){cin>>a[i][j];}}for(int i=1;i<=x;i++){for(int j=1;j<=y;j++){cin>>b[i][j];}}for(int i=1;i<=x;i++){for(int j=1;j<=y;j++){cout<<b[i][j]+a[i][j]<<" ";}cout<<endl;}return 0;
}

 这里可以看到,二维数组的输入是由双重循环构成的,分别是行和列,是几维数组,就嵌套几个循环。那么每个元素都是由行和列来定位下标。特别提醒,如果要输出二维数组,在第一个循环最后一定要加入endl换行。(粉丝要破200了,开心)


http://www.mrgr.cn/news/71029.html

相关文章:

  • 微服务学习重点:底层的实现逻辑
  • 源码解析-Spring Eureka
  • 【C++ 算法进阶】算法提升十三
  • 亮眼!创新发文!双重分解+遗传优化+深度学习!CEEMDAN-Kmeans-VMD-GA-Transformer多元时序预测
  • Vivado+Vscode联合打造verilog环境
  • 【机器学习】K近邻算法
  • 世界职院技能大赛视角下,高职高专技能人才高阶素养培育路径探究
  • CRM系统用户满意度调查:哪些品牌最受欢迎
  • 量化交易系统开发-实时行情自动化交易-3.4.1.4.A股衍生数据
  • Spring资源加载模块,原来XML就这,活该被注解踩在脚下 手写Spring第六篇了
  • 浅谈c++函数调用以及析构函数为虚函数的原因
  • 基于Ubuntu2410脚本搭建OpenStack-D版
  • 青训5_1112_01 小S的倒排索引(内置方法 set(a) set(b) 及sorted 排序)
  • No module named ‘torch.nn.attention‘
  • 【C++】C++基础知识
  • 期权懂|你知道场外个股期权该如何参与吗?
  • 微服务改造:踩过的坑!
  • 2. Sharding-JDBC广播表和绑定表操作
  • 阿里云Linux安装Docker服务报错问题
  • 【轻松远程处理图片:在线图片编辑工具Photopea群晖NAS部署解决方案】
  • 解决 C/C++ 中 “invalid use of incomplete type” 编译错误
  • 【前端】深入浅出的React.js详解
  • Spring Boot编程训练系统:深入设计与实现
  • 双指针算法的妙用:提高代码效率的秘密(3)
  • 【三宝的身高】
  • 数据湖系列之四 | 数据湖存储加速方案的发展和对比分析