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

数据结构-二维数组

二维数组可以理解为数组的数组。二维数组组织为矩阵,可以表示为行和列的集合。

但是,创建二维数组以实现关系数据库外观相似的数据结构。它提供了一次容纳大量数据的便利性,可以在任何需要的地方传递给任意数量的功能。

1. 如何声明二维数组

声明二维数组的语法与一维数组的语法非常相似,如下所示 -

int arr[max_rows][max_columns];

C

它产生的数据结构如下所示 -

上图显示了二维数组,元素以行和列的形式组织。 第一行的第一个元素由[0][0]表示,其中第一个索引中显示的数字是行的数字,而第二个索引显示的数字是列的数字。

2.如何访问二维数组的数据

由于二维数组的元素可以随机访问。这与一维数组类似,可以使用单元格的索引访问二维数组中的各个单元格。将两个索引值附加到特定单元格,一个是行号,另一个是列号。

使用以下语法将存储在二维数组的任何特定单元格中的值存储到某个变量x

int x = a[i][j];

C

其中ij分别是单元格的行号和列号。使用以下代码将二维数组的每个单元格分配0值:

for ( int i=0; i<n ;i++)  
{  for (int j=0; j<n; j++)   {  a[i][j] = 0;   }  
}

C

3.初始化二维数组

当同时在C语言编程中声明和初始化一维数组时,不需要指定数组的大小。 但是这不适用于二维数组。必须至少定义数组的第二个维度。

声明和初始化二维数组的语法如下 -

int arr[2][2] = {0,1,2,3};

C

二维数组的元素数量总是等于:行数 * 列数 。

示例: 将用户数据存储到二维数组并打印。

C语言的实现

#include <stdio.h>  
void main()
{int arr[3][3], i, j;for (i = 0;i < 3;i++){for (j = 0;j < 3;j++){printf("Enter a[%d][%d]: ", i, j);scanf("%d", &arr[i][j]);}}printf("\n printing the elements ....\n");for (i = 0;i < 3;i++){printf("\n");for (j = 0;j < 3;j++){printf("%d\t", arr[i][j]);}}
}

C

Java语言的实现

import java.util.Scanner;  
public class TwoDArray {  public static void main(String[] args) {  int[][] arr = newint[3][3];  Scanner sc = new Scanner(System.in);  for (inti =0;i<3;i++)  {  for(intj=0;j<3;j++)  {  System.out.print("Enter Element");  arr[i][j]=sc.nextInt();  System.out.println();  }  }  System.out.println("Printing Elements...");  for(inti=0;i<3;i++)  {   System.out.println();  for(intj=0;j<3;j++)  {  System.out.print(arr[i][j]+"\t");  }  }  }  
}

Java

C#语言的实现

using System;  public class Program  
{  public static void Main()  {  int[,] arr = new int[3,3];  for (int i=0;i<3;i++)  {  for (int j=0;j<3;j++)  {  Console.WriteLine("Enter Element");  arr[i,j]= Convert.ToInt32(Console.ReadLine());  }  }  Console.WriteLine("Printing Elements...");  for (int i=0;i<3;i++)  {  Console.WriteLine();  for (int j=0;j<3;j++)  {  Console.Write(arr[i,j]+" ");  }  }  }  
}

C#

4.将二维数组映射到一维数组

在映射二维数组时,大多数人可能会问为什么需要这种映射。创建二维数组和实现关系数据库表看起来有相似的数据结构,在计算机存储器中,二维数组存储技术类似于一维数组的存储技术。

二维数组的大小等于行数和数组中存在的列数的乘积。 确实需要将二维数组映射到一维数组,以便将它们存储在内存中。

一个3 X 3的二维数组如下图所示。 但是,需要将此数组映射到一维数组,以便将其存储到内存中。

将二维数组元素存储到存储器中有两种主要技术 -

4.1.行主顺序

在行主排序中,二维数组的所有行连续地存储在存储器中。 考虑一下上图中所示数组,它按行主顺序的存储器分配如下所示 -

首先,数组的第一行完全存储到存储器中,然后数组的第二行完全存储到存储器中,直到最后一行也完全存储到存储器中。

4.2.列主顺序

根据列主排序,二维数组的所有列都连续地存储在存储器中。 上面图像中所示数组的存储器分配给出如下 -

首先,数组的第一列完全存储到存储器中,然后数组的第二行完全存储到存储器中,直到数组的最后一列。

5.计算二维数组随机元素的地址

由于存在两种不同的将二维数组存储到存储器中的技术,因此也有两种不同的公式来计算二维数组的随机元素的地址。

5.1. 按行主顺序

如果数组由a[m][n]声明,其中m是行数,而n是列数,则以行主顺序存储的数组的元素a[i][j]的地址计算为,

Address(a[i][j]) = B. A. + (i * n + j) * size

Shell

其中,B. A.是基数地址或数组a[0][0]的第一个元素的地址。

示例:

a[10...30, 55...75], 基地址 array (BA) = 0 , 一个元素的大小 = 4 字节 。
计算 a[15][68] 的地址为 -    Address(a[15][68]) = 0 +   
((15 ? 10) x (68 ? 55 + 1) + (68 ? 55)) x 4  = (5 x 14 + 13) x 4  
= 83 x 4   
= 332

Shell

5.2. 按列主顺序

如果数组由a[m][n]声明,其中m是行数,而n是列数,则以列主顺序存储的数组的元素a[i][j]的地址计算为,

Address(a[i][j]) = ((j*m)+i)*Size + BA

其中,BA是数组的基地址。

示例

A [-5 ... +20][20 ... 70], BA = 1020, 元素的大小为 = 8 字节。计算 a[0][30] 的位置是 - 地址 [A[0][30]) = ((30-20) x 24 + 5)  x 8 + 1020   =  245 x 8 + 1020 = 2980 字节

http://www.xdnf.cn/news/11471.html

相关文章:

  • HTTP代理和SOCKS代理
  • Fortran语言的入门与心得
  • BST(二叉搜索树)
  • finalize方法_finalize()方法详解
  • HLS RTSP RTMP的区别
  • java injection_injection(注入)
  • MySql下载和安装
  • Linux基础知识汇总,收藏
  • 推荐几个精致的web UI框架及常用前端UI框架(1),web开发进阶
  • 各类编程语言的历史以及现状发展情况
  • jquery实现移动端slotmachine抽奖游戏,中奖后并弹出地址填写框
  • 常见CMS系统总结
  • 【图割】最大流最小切割的最直白解读
  • Cadence Allegro如何修改原点位置
  • Win10 + Ubuntu 双系统完美避坑删除 Ubuntu 教程_win10和ubuntu双系统删除ubuntu(1)
  • 使用MFC实现WIN10的气泡提示
  • 显示农历天气时钟小部件下载_安卓最强桌面小部件:Zooper Widget
  • Hadoop之分块、分片与shuffle机制详解
  • 尼采:快乐的知识(上)
  • 与善淘网一起做慈善商店
  • 3D设计必备!5个免高质量的 HDRI 环境贴图网站
  • C语言中钩子函数使用讲解
  • 100个vc/c/c++语言学习网站/学习教程
  • 手机ROM简单制作过程
  • visual studio 2010 破解版 破解方法
  • 问题:给DIV设置半透明层,用CSS实现半透明效果呢?
  • @OutputCache 配置参考
  • HTML5生日蛋糕网页设计与制作 生日祝福制作代码 生日快乐网页模板【生日蛋糕树】HTML+CSS+JavaScript html七夕情人节网页制作
  • 10款屏幕取色器/颜色拾取工具软件介绍及下载地址[转]
  • 哪些网站可以发外链?分享几十个个可以发外链的网站