C语言二维数组超细讲解
用一维数组处理二维表格,实际是可行的,但是会很复杂,特别是遇到二维表格的输入、处理和输出。
在你绞尽脑汁的时候,二维数组(一维数组的大哥)像电视剧里救美的英雄一样显现在你的面前,初识数组的朋友们还等什么呢?让我们认识一下这位武功高强的大哥吧!
1. 双下标变量
聪明的你一定能够顾名思义了吧,简单举个例子:Array [2] [3]
Array 是数组名,后面的两个方括号内分别放行下标和列下标,这里的行下标和列下标就是所谓的双下标。
这里的下标规则和一维数组的下标规则一模一样:
(1)可以是正的整形变量:
eg:Array [2] [3];
(2)可以是字符常量:
eg:Array [‘A’] [‘B’] = Array [65] [66];(不清楚字符常量的同学可以点击:
(3)可以是有确定值的表达式:
eg:Array [i+1] [j+2]、Array [ A[1] ] [ A[2] ];
总而言之,这里的下标分别表示行数和列数。
接下来和小编一起感受一下双下标变量的威力。
上下标变量可以使方程组的计算更简单,比如:
计算一个二元一次线性方程组:
$$\left\{\begin{matrix}7*x_{1}-4*x_{2}=7\\-2*x_{1}+3*x_{2}=-1\end{matrix}\right.$$
它的一般表达式为:
$$\left\{\begin{matrix}a11*x1+a12*x2=b1\\a21*x1+a22*x2=b2\end{matrix}\right.$$
我们可以写出一个该方程组的增广矩阵:
$$\begin{pmatrix}a11& a12& b1\\a21& a22& b2\end{pmatrix}$$
运用克拉默法则可得:
$$x1=(b1*a22-b2*a12)/(a11*a22-a21*a12)$$
$$x2=(a11*b2-a21*b1)/(a11*a22-a21*a12)$$
因为矩阵的本质其实就是二维数表,我们可以用二维数组来表示这个方程组的系数。
我们先定义一个二维数表:a[2][2],和一个一维数表:b[2]
那么a11可以写成:a[0][0],a12可以写成 a[0][1],a21,a22同理。则:
$$x1=(b[0]*a[1][1]-b[1]*a[0][1])/(a[0][0]*a[1][1]-a[1][0]*a[0][1])$$
x2道理一样。
所以,通过双下标变量,我们只需要为a[i][j],b[i]中的元素赋值,便可以轻松解决方程组的问题。
另外,通过双下标变量来表示一张二维数表,使下标变量的行列下标正好与数据在表格中的位置相对应,形象直观地反映了二维表格。
2. 二维数组定义
很简单,由双下标变量定义的数组就称为二维数组,双下标变量就是数组的元素。
二维数组定义的一般形式和一维数组大同小异,只是下表中的常量表达式多了一个(维度加一):
<类型标识符> <数组名标识符> [<常量表达式>] [<常量表达式>]
例如:float a [3] [4],b [5] [6];
这里的float表示二维数组中元素的类型是单精度浮点型,a、b就是给数组取的名字。
注意:a [3] [4] 千万千万不要写成 a [3 , 4] !
上面我们把二维数组理解成二维图表,我们也可以将二维数组看成元素是一维数组的一维数组,将维数降低。
比如 a [3] [4],我们可以把a看成一个一维数组,里面有三个元素:a [0]、a [1]、a[2],每个元素又包含4个元素:
| a [0] | a [0] [1] | a [0] [2] | a [0] [3] | a [0] [4] |
| a [1] | a [1] [1] | a [1] [2] | a [1] [3] | a [1] [4] |
| a [2] | a [2] [1] | a [2] [2] | a [2] [3] | a [2] [4] |
这种理解方法在数据初始化和用指针表示时显得很方便。
在C语言中,二维数组中元素排列的顺序是按行存放的,就是说先排列第一行的数据,再排列下第二行的数据,以此类推。如图:

数组元素可以出现在表达式中也可以被赋值,例如:b [1] [2] = a [1] [3] / 2。
小编在这里想提醒一下:要严格区分定义数组时用的 a [5] [6] 和引用元素时的 a [5] [6] 的区别哦!
3. 二维数组的初始化
对二维数组的初始化有一下几种办法:
(1)分行给二维数组赋值
这个方法用到了我们前面讲的对二维数组的降维理解,比如:
int a [2] [3] = {{1, 2, 3}, {4, 5, 6}};
此语句先将第一行元素依次赋值为:1、2、3,然后将第二行元素赋值为:4、5、6,因此说是按行赋值。
(2) 可以只有一个花括号,按二维数组元素的排列顺序对各元素依次赋值
比如:
int a [2] [3] = {1, 2, 3, 4, 5, 6};
(3)对部分元素赋初值
①
int a [2] [3] = {{2}, {4}};
此语句表示只给第一行第一个元素赋值为2,第二行第一个元素赋值为4,而其他元素都为0。
②
int a [2] [3] = {{1, 2, 3}};
此语句表示只给第一行三个元素分别赋值为:1、2、3。
③
int a [2] [3] = {{},{1, 2, 3}};
此语句表示只给第二行三个元素分别赋值为:1、2、3。
(4)定义数组时对第一维的长度可以不定义,但必须定义第二维的长度
例:
int a [] [3] = {1, 2, 3, 4, 5, 6};
系统会根据输入的总个数分配存储空间,易知这个二维数组有二行;
再如:

有关二维数组的知识就讲到这里啦,欢迎小伙伴来交流哦!
预告:二维数组的应用
2020-04-21
17:26:54
C语言二维数组超细讲解的更多相关文章
- c语言二维数组传递
c语言二维数组传递,目前我总结三种方法,以及纠正一个不能使用的方法 /********************************* * 方法1: 第一维的长度可以不指定 * * 但必须指定第二维 ...
- C语言字符数组超细讲解
看到标题,有不少朋友会想:字符数组不也是数组吗?为什么要单独拿出来讲哩?莫非它是朵奇葩? 哈哈,确实,一起来认识一下这朵数组界的奇葩吧! 一.字符数组的定义.引用.初始化 大家好!我是字符数组,看我的 ...
- C语言二维数组
上节讲解的数组可以看作是一行连续的数据,只有一个下标,称为一维数组.在实际问题中有很多数据是二维的或多维的,因此C语言允许构造多维数组.多维数组元素有多个下标,以确定它在数组中的位置.本节只介绍二维数 ...
- 关于c语言二维数组与指针的个人理解及处理办法。
相信大家在学习C语言时,对一维数组和指针的理解应该是自信的,但是,我在学习过程中,看到网上一些博文,发现即便是参加工作的一些专业编程人员,突然碰到二维数组和指针的问题时,也可能会遇到难以处理的诡异问题 ...
- C语言 二维数组复制、清零及打印显示
#include <stdlib.h> #include <stdio.h> #include <string.h> //二维整型数组打印显示 ],int row, ...
- C语言二维数组作业
一.PTA实验作业 题目1:7-3 出生年 1. 本题PTA提交列表 2. 设计思路 1.声明一个函数different()用来计算一个年份的不同数字个数 2.定义y(y是来计算符合要求的年份的量), ...
- C语言 二维数组(指针)动态分配和释放(转)
C 二维数组(指针)动态分配和释放 先明确下概念: 所谓32位处理器就是一次只能处理32位,也就是4个字节的数据,而64位处理器一次就能处理64位,即8个字节的数据.如果我们将总长128位的指令分别按 ...
- C语言二维数组作为函数参数
设有整型二维数组a[3][4]如下:0 1 2 34 5 6 78 9 10 11 它的定义为: int a[3][4]={{0,1,2,3},{4,5,6,7} ...
- C语言二维数组作为函数的参数
前言:今天在实现装配线调度程序时候,用到了二维数组,并将其作为函数的参数.在写程序的时候,遇到一些问题,即二维数组做函数的参数应该如何正确表示.我写程序的错误如下程序所示: #include < ...
随机推荐
- C# NAudio录音和播放音频文件及实时绘制音频波形图(从音频流数据获取,而非设备获取)
下午写了一篇关于NAudio的录音.播放和波形图的博客,不太满意,感觉写的太乱,又总结了下 NAudio是个相对成熟.开源的C#音频开发工具,它包含录音.播放录音.格式转换.混音调整等功能.本次介绍主 ...
- 【总结】办公&编程&学习你可能需要这些小利器!
偶然想到自己从最开始的编程小白,什么都不懂,看啥啥新鲜的时期,到现在颇有"蓦然回首,那人却在灯火阑珊处"的感觉,遂想整理一下这一路学习我个人发现的在办公.编程或者学新知识等方面针对 ...
- HDU-6376 度度熊剪纸条
链接 http://acm.hdu.edu.cn/showproblem.php?pid=6376 分析 这道题好像不是很难,因为是要拼出前缀1,所以确定剪下每一段1需要的刀数,然后因为有次数限制,所 ...
- GitLab → 搭建中常遇的问题与日常维护
开心一刻 隔壁有一个80多岁的老大爷,昨天在小区的一棵树下发现一条黑色的蛇,冻僵了,大爷善心大发,就把蛇揣在了怀里,想给它一点温暖. 今天一大早看到大爷在树上挂了一个牌子,写到:不准随地大小便! 搭建 ...
- OpenCV-Python 交互式前景提取使用GrabCut算法 | 三十五
目标 在本章中, 我们将看到GrabCut算法来提取图像中的前景 我们将为此创建一个交互式应用程序. 理论 GrabCut算法由英国微软研究院的Carsten Rother,Vladimir Kolm ...
- 用卷积神经网络和自注意力机制实现QANet(问答网络)
欢迎大家关注我们的网站和系列教程:http://www.tensorflownews.com/ ,学习更多的机器学习.深度学习的知识! 在这篇文章中,我们将解决自然语言处理(具体是指问答)中最具挑战性 ...
- CodeForces - 1244E
题意:给n个数,可以有k次的 + 1或 - 1,在k次操作之内,让n个数的最大值和最小值差最小. 思路:要让max和min的差值最小,也就等同于min--,max++,如果k==0结束操作,或者min ...
- 大O 表示法
大O表示法 指出了算法有多快.例如,假设列表包含n个元素.简单查找需要检查每个元素,因此需要执行n次操作.使用大O表示法,这个运行时间为O(n).单位秒呢?没有——大O表示法指的并非以秒为单位的速度. ...
- 火焰图--记一次cpu降温过程
引子 正值周末,娃儿6:30又如闹铃般准时来叫醒了我们.年前离开美菜,又回到了杭州.原本是想有更多时间陪伴娃儿,然而新的工作节奏与工作地点,让我们每天都是早上见面:这不,为了周末可以多玩一会儿,早早就 ...
- ML-Agents(四)GridWorld
目录 ML-Agents(四)GridWorld Visual Observations Masking Discrete Actions 环境与训练参数 场景基本结构 代码分析 环境初始化代码 Ag ...