`
frank-liu
  • 浏览: 1684114 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

矩阵的对角遍历分析

 
阅读更多

问题简介:

    以对角线的方式从左至右或者从右至左的遍历一个矩阵。这个矩阵更确切的说是一个行和列都长度相等的方阵。比如说,我们按照从左到右,从上到下的方式遍历一个矩阵。如下图所示:

那么我们遍历的序列将如下:1, 2, 5, 3, 6, 9 4, 7, 10, 13, 8, 11, 14 12, 15, 16.

这是一个比较常见的问题。以前在一些面试中也碰到过。一般来说,只是顺序的遍历每行每列显得过于简单。而通过对角访问的时候,我们可以看到,对应要遍历的行数为矩阵行数的2倍减1.

 

问题分析:

方法1:

    以前面的问题为例,粗看如果要遍历对角的数据,需要首先从第一行开始,每一次找到在它左下角方向的元素,也就是假定取第一行的元素a[0][j],则对应该序列后面的元素分别为a[1][i - 1], a[2][i-2]...a[i][0]。这样我们就遍历完了上面一半的内容,一直到右上到左下的对角线。

    遍历完了这部分之后我们就要从第一行的最后一列开始,一直到最右下角。每个序列每次行号增加1,列号减1,一直增加到最后一行。生成的序列应该类似如下:a[1][n-1], a[2][n-2]...a[n-1][1]

经过前面的讨论,我们可以得出如下部分的代码:

 

public static void traverseNoCopy(int[][] a)
{
	// Traverse the upper part
	for(int j = 0; j < a[0].length; j++)
	{
		for(int k = 0; k <= j; k++)
		{
			System.out.print(a[k][j - k] + " ");
		}
		System.out.println();
	}

	// Traverse the lower part
	for(int i = 1; i < a.length; i++)
	{
		for(int j = i; j < a.length; j++)
		{
			System.out.print(a[j][a.length - j + i - 1] + " ");
		}
		System.out.println();
	}
}

 这个遍历的过程中,最难的地方是这个矩阵的遍历要分成两块,上面部分对应的二重循环中两个下标的关系和下面部分的不一样。要找到对应的关系则需要列出几个元素的序列来寻找其中的规律。

 

 方法2:

        和方法1比起来,这种方法需要占用额外的空间,但是相对来说更容易理解一点。我们看前面的矩阵图。当我们要从右上到左下遍历的时候,对应这个元素下面一行的元素是在它对应列元素左边一个。后面的元素依次类推。那么,既然如此,如果我们将每一行元素下面一行的元素依次向右移动一位,那该如何呢?这样,将构成一个如下图的样子:

 

        一个有意思的地方就是,原来我们需要斜角去访问的地方,现在只需要逐列的访问就可以了。为了实现这么一个结构,我们需要额外构造一个2n -1维的矩阵,然后从左到右按列遍历矩阵就实现了同样的效果。根据这种思路,得到的代码如下:

public static void traverse(int[][] a)
{
	// Suppose we traverse from left to right and from upper right to lower left
	int[][] b = new int[a.length * 2 - 1][a.length * 2 - 1];

	// Copy every row in a and make some offset accordingly
	for(int i = 0; i < a.length; i++)
	{
		for(int j = 0; j < a.length; j++)
		{
			b[i][i + j] = a[i][j];
		}
	}

	// Traverse every column from left to right
	for(int i = 0; i < b.length; i++)
	{
		for(int j = 0; j < b.length; j++)
		{
			if(b[j][i] != 0)
				System.out.print(b[j][i] + " ");
		}
		System.out.println();
	}
}

这种方式遍历的时候我们需要有一个假定,就是假设我们我们新构造的矩阵中,新增加的元素必须和原来矩阵中的元素不一样。否则按列遍历的时候会产生混淆。这里只是简单的用0来表示。具体实现的时候需要根据情况来调整。

总结:

        矩阵对角遍历的两种方法中,第一种方法的要点在于要根据遍历的顺序和方向来推断矩阵元素下标的变化规律。有时候找到这些规律会比较费时间一点。第二种方法则比较简单直观一些,首先推断出行之间元素的位置偏移,然后构造一个对应的偏移矩阵。这种方法的好处就是不需要费脑筋去推算下标变化的关系,之需要构造出来然后遍历就可以了。当然,这样做比较费空间,同时也需要保证元素的独特性以防止遍历的时候产生混淆。

  • 大小: 14.7 KB
  • 大小: 12.5 KB
分享到:
评论

相关推荐

    矩阵对角线元素的和1

    在给定的编程问题中,任务是计算一...总结来说,这个问题是关于遍历矩阵并计算特定对角线元素的和,通过双层循环和条件判断,我们可以有效地解决这个问题。提供的解决方案正是采用了这种方法,有效地实现了所需的功能。

    4*4矩阵对角线之和

    使用了两种循环:`for`循环,用来遍历数组并计算对角线之和。 ```cpp for(int i=0; i; i++) sum += a[i][i]; sum += a[0][3] + a[1][2] + a[2][1] + a[3][0]; ``` ### 4. 计算对角线之和的算法分析 #### 方法一 ...

    java写的递归遍历矩阵源码

    通过调整`traverseMatrix`函数中的边界条件和递归调用顺序,可以轻松实现其他遍历策略,如列优先或对角线优先。 在实际开发中,源码可能还包括异常处理、性能优化等额外功能。`README.md`文件通常包含项目的简介、...

    C++求一个3×3矩阵对角线元素之和

    // 遍历矩阵并累加对角线元素 for (int i = 0; i ; i++) { sum += matrix[i][i]; // 当前行的对角线元素为matrix[i][i] } cout 对角线元素之和为:" ; // 输出结果 return 0; } ``` 在上述代码中,我们首先...

    托普利茨矩阵(遍历比较)1

    **托普利茨矩阵**(Toeplitz Matrix)是一种特殊类型...在编程实现中,通过遍历并比较相邻对角线元素,我们可以有效地判断一个矩阵是否符合托普利茨矩阵的定义。对于给定的 LeetCode 题目,这样的方法是有效且直接的。

    python 实现方阵的对角线遍历示例

    对一个方阵矩阵,实现平行于主对角线方向的对角线元素遍历。 从矩阵索引入手: [[ 1 2 3 4 5] [ 6 7 8 9 10] [11 12 13 14 15] [16 17 18 19 20] [21 22 23 24 25]] 上三角的索引遍历: 0 0 1 1 2 2 3 3 4 4 0...

    c语言三对角矩阵的压缩存储

    具体实现时,我们首先定义一个足够大的一维数组,然后遍历三对角矩阵的每个元素,只将非零元素存入数组。为了进行加减乘除运算,我们需要维护矩阵的行数和列数,以便知道哪些位置的元素应该对应到原矩阵的哪个位置。...

    递归遍历矩阵.rar

    当到达最后一列时,我们回溯到当前行的前一列,这样可以沿着对角线向右下方移动,直到整个矩阵被遍历。 递归遍历矩阵的优势在于其简洁性和可读性,但需要注意的是,由于递归涉及到函数调用,如果矩阵过大,可能会...

    将一个矩阵的上对角线加1,下对角线减1(C语言原代码)

    标题中的任务是使用C语言编写一段程序,该程序将矩阵的上对角线元素加1,下对角线元素减1。这个操作在数学或编程领域中可能用于矩阵的特定变换,例如创建某些特殊矩阵或者作为算法的一部分。下面是对这个程序的详细...

    python实现二维数组的对角线遍历

    4. **反转列索引**:由于是从右上角到左下角遍历,因此需要将 `list_j` 反转以适应遍历方向。 5. **打印结果**:根据 `list_i` 和反转后的 `list_j` 访问数组中的元素并打印出来。 ```python # 定义二维数组 A A = ...

    计算矩阵对角线和的 Java 程序.docx

    矩阵对角线的和是指主对角线(也称为对角线)和次对角线(也称为副对角线)上元素的总和。本节将详细介绍如何编写一个 Java 程序来计算给定的 N * N 二维矩阵的主对角线和次对角线之和。 首先,理解矩阵的基本概念...

    VB.rar_对角矩阵 vb_矩阵 vb

    为了在VB中实现导纳阵算法,我们需要遍历电路图,计算每个节点的导纳,然后将这些值填入对角矩阵。这涉及到基本的电路理论和计算,如欧姆定律和基尔霍夫定律的应用。一旦导纳矩阵构建完成,我们可以通过它来解决电路...

    VB 矩阵的上、下三角

    3. **获取上三角矩阵**:对于一个给定的矩阵,通过遍历数组,我们可以只保留主对角线及以下的元素。这可以通过两个嵌套For循环实现,外层循环遍历行,内层循环遍历列。如果当前元素的列索引小于行索引,那么该元素...

    递归遍历矩阵源代码技术资料

    4. **自定义遍历**:根据具体需求,还可以设计各种自定义的递归遍历方式,例如基于特定规则的遍历,如“之”字形遍历、对角线遍历等。 源代码技术资料可能包含以下内容: 1. **基础数据结构**:如何用数组或链表等...

    java源码:递归遍历矩阵.zip

    在Java编程领域,递归遍历矩阵是一种常见的算法技术,特别是在处理二维数组或者多维数组时。本资源“java源码:递归...如果你正在学习Java或数据结构与算法,深入研究这个递归遍历矩阵的示例将对你的技能提升大有裨益。

    TanaStudy#java-study#Q498对角线遍历1

    给你一个大小为 m x n 的矩阵 mat ,请以对角线遍历的顺序,用一个数组返回这个矩阵中的所有元素。示例 1:输出:[1,2,4,7,5,3,6,8,9]示

    二维数组遍历

    第二种遍历方式是按照逆向对角线方向遍历二维数组,并且每遍历完一条对角线后,同时打印该对角线与其对称位置的另一条对角线上的元素。 ```c for (int i = 0; i ; i++) { int k = MAX - i - 1; for (int j = 0; j...

    基于java的递归遍历矩阵源代码.zip

    递归遍历矩阵在实际应用中有多种用途,如图像处理(如查找特定模式)、游戏AI(如搜索路径)、数据结构分析等。了解如何在Java中使用递归遍历矩阵是提升编程技能和解决问题能力的重要一步。通过阅读并理解“Matrix....

    两个矩阵同时相似对角化的MATLAB程序.docx

    在MATLAB中,两个矩阵同时相似对角化是一个复杂的过程,涉及到线性代数中的重要概念,如矩阵的相似对角化、特征值、特征向量以及矩阵乘法的交换律。本文主要介绍如何利用MATLAB编程实现这个过程。 首先,我们需要...

Global site tag (gtag.js) - Google Analytics