C++013-C++二维数组

简介: C++013-C++二维数组

C++013-C++二维数组



在线练习:

http://noi.openjudge.cn/

https://www.luogu.com.cn/


二维数组


目标

了解矩阵、二维数组的基本概念

掌握二维数组输入输出基本框架

掌握二维数组元素访问和遍历的方法


6242e140137dd75b019917bc31ed190e_3d5b883233ed4ba5b5dbb7870152bcec.png


二维数组存储

array[3][4]就是一个二维数组,二维数组的存储方式与一维数组类似,都是连续存储的。


591783a1701d7d364e435fd716014443_3bcf7fd0e33147b6af5793897e1d73f1.png

5d16afab44e25410799447484965e5f9_68b8b13bbcb1456094b89f79c8563968.png


二维数组定义

数据类型 数组名[数组长度][数组长度];


int a[3][4];
//定义里面都是整形变量的数组a

其中,a是二维数组的数组名,该数组有3*4=12个元素,依次表示为:.


ef719838d81add5c4f36ce2af68f6eab_4043b1ed797942c28e6467581c16c51b.png

二维数组初始化


51786a3199923053d8348b65e47d5301_50dfd9740f0e4e2eafa155aa047d9bd7.png

646e4ee545d0034f5c1dacd11436e7d5_543dc6ea086f4288a049cb700af28c62.png


二维数组输入输出

#include <iostream>
//#include<bits/stdc++.h>
using namespace std;
int main()
{
    int a[10][10];
    for(int i=1;i<=3;i++){
        for(int j=1;j<=4;j++){
            cin>>a[i][j];
        }
    }
    for(int i=1;i<=3;i++){
        for(int j=1;j<=4;j++){
            cout<<a[i][j]<<" ";
        }
        cout<<endl;
    }
    return 0;
}

输出为:

1705034245f1887620489c573c8f0118_b2905ba776f440e38293f5352b15333a.png


二维数组定义的时候可以在主函数之外定义,因为一般情况下二维数组较大,占的空间较多。定义在主函数之外可以分配较大的内存(超过10万个int整数),且数组里面的所有元素都会默认赋值为0。(一维数组和变量也可以定义在主函数之外)这样的定义叫做全局数组(变量)。


矩阵的对角线

在一个m行m列的矩阵中,从左上角到右下角这一斜线上的m个元素的位置,叫做主对角线。从右上角到左下角这一斜线上的m个元素的位置,叫做副对角线。


主对角线方向(主线)的元素特点:若行号–列号+m = k,那么这个元素在第k条主线上;

副对角线方向(副线)元素特点:若行号+列号-1=k,那么这个元素在第k条副线上;

43736a656759d7b54d5bac13ea11b464_5591c3701056457f8d028525682bbae4.png


题目描述 输出m*m方阵的主对角线上的元素

#include <iostream>
//#include<bits/stdc++.h>
using namespace std;
int a[101][101],m;
int main()
{
    cin>>m;
    for(int i=1;i<=m;i++){
        for(int j=1;j<=m;j++){
            cin>>a[i][j];
        }
    }
    for(int i=1;i<=m;i++){
        for(int j=1;j<=m;j++){
            if(i==j) cout<<a[i][j]<<" ";
        }
        //cout<<endl;
    }
    return 0;
}

输出为:

32ac0e30aeb3f6f0380be3eb360d2947_3ee53bbe2e784ddfa255c9b5d97aeee2.png


在线练习:


http://noi.openjudge.cn/


总结


本系列为C++学习系列,会介绍C++基础语法,基础算法与数据结构的相关内容。本文为C++二维数组案例,包括相关案例练习。

相关文章
|
6月前
|
存储 算法 编译器
|
6月前
|
存储 C++ 计算机视觉
C++程序二维数组:深入理解与实践
C++程序二维数组:深入理解与实践
64 1
|
6月前
|
存储 安全 编译器
【C++从练气到飞升】03---C++入门(三)
【C++从练气到飞升】03---C++入门(三)
|
6月前
|
Unix 编译器 C语言
【C++从练气到飞升】01---C++入门(一)
【C++从练气到飞升】01---C++入门(一)
|
6月前
|
存储 自然语言处理 编译器
【C++从练气到飞升】02---C++入门(二)
【C++从练气到飞升】02---C++入门(二)
|
6月前
|
存储 程序员 C语言
【C/C++ 数据结构 】二维数组结构解析
【C/C++ 数据结构 】二维数组结构解析
97 0
|
6月前
|
存储 编译器 C++
c++二维数组定义方程的讲解
c++二维数组定义方程的讲解
39 0
|
6月前
|
Go C++ Java
C/C++每日一练(20230412) 二维数组找最值、排序
C/C++每日一练(20230412) 二维数组找最值、排序
65 0
C/C++每日一练(20230412) 二维数组找最值、排序
|
6月前
|
算法 C++
C++021-C++二分查找
C++021-C++二分查找
C++021-C++二分查找
|
6月前
|
算法 C++
C++020-C++因数,公因数,公倍数
C++020-C++因数,公因数,公倍数
C++020-C++因数,公因数,公倍数