`
云之遥
  • 浏览: 8640 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

二维数组螺旋式输出

阅读更多
package algorithm;


public class ArrayHelix {

	public static Integer[][] doubleArray = new Integer[][]{{2, 3, 4},
															{11, 12, 5},
															{10, 13, 6},
															{9, 8, 7}};
	
	public static void example() {
		char[] dire = {'E', 'S', 'W', 'N'};
		char p = dire[0];
		boolean loop = true;
		int h1 = 0, h2 = doubleArray[0].length - 1;
		int v1 = 0, v2 = doubleArray.length - 1;
		
		int i = 0;
		while (loop) {
			p = dire[i];
			if (v1 > v2 || h1 > h2) {
				loop = false;
			}
			switch (p) {
			case 'E':
				forwardPrint(h1, h2, v1, v1, doubleArray);
				++v1;
				break;

			case 'S':
				forwardPrint(h2, h2, v1, v2, doubleArray);
				--h2;
				break;
				
			case 'W':
				reversePrint(h1, h2, v2, v2, doubleArray);
				--v2;
				break;
				
			case 'N':
				reversePrint(h1, h1, v1, v2, doubleArray);
				++h1;
				break;
			default:
				break;
			}
			++i;
			if (4 == i) {
				i = 0;
			}
		}
	}
	
	public static void forwardPrint(int a1, int a2, int b1, int b2, Integer[][] c) {
		for (int i = b1; i <= b2; ++i) {
			for (int j = a1; j <= a2; ++j) {
				System.out.print(c[i][j] + ", ");
			}
		}
	}
	
	public static void reversePrint(int a1, int a2, int b1, int b2, Integer[][] c) {
		for (int i = b2; i >= b1; --i) {
			for (int j = a2; j >= a1; --j) {
				System.out.print(c[i][j] + ", ");
			}
		}
	}
	
	public static void main(String[] args) {
		example();
	}
}
分享到:
评论

相关推荐

    螺旋输出二维数组

    螺旋输出二维数组是一种在编程中处理二维数组时常见的操作,特别是在数据展示或处理特定顺序时。这个算法的主要目的是按照顺时针或者逆时针的方向依次访问数组中的元素,形成一个螺旋状的输出。 在给定的代码中,...

    螺旋式遍历二维数组(矩阵)Demo

    螺旋式遍历二维数组,也称为矩阵的螺旋顺序遍历,是一种常见的算法问题,它涉及到对二维数组元素的特殊访问顺序。在这个问题中,我们从数组的最外层开始,按照顺时针方向(上→右→下→左)依次访问元素,直到访问完...

    螺旋矩阵 java

    螺旋矩阵是一种按照特定顺序填充数字的二维数组。在本篇文章中,我们将详细介绍如何使用Java编写一个螺旋矩阵生成器。该程序通过调整方向变量来控制填充数字的方向,从而实现螺旋式填充。 #### 二、螺旋矩阵的概念 ...

    解决输出顺时针螺旋数组问题【寻路算法】

    这个问题的主要目标是将一个二维数组按照顺时针方向输出,即从左上角开始,沿着外层边界螺旋式地遍历整个数组。寻路算法在这里扮演着关键角色,因为它涉及到如何有效地遍历矩阵的每一个元素。 首先,我们需要理解二...

    逆时针螺旋式旋转输出

    逆时针螺旋式输出是一种常见的编程问题,主要涉及到矩阵数据结构的操作。在这个问题中,我们需要将一个二维数组或矩阵按照逆时针方向进行螺旋式的输出。这种操作在数据处理、图像处理以及某些算法实现中都有可能用到...

    c++实现在螺旋矩阵,有螺旋动画

    在C++编程中,螺旋矩阵是一种特殊的二维数组,它的元素按照顺时针或者逆时针方向螺旋式地填充。在给定的标题“c++实现在螺旋矩阵,有螺旋动画”中,我们可以推断出这个程序不仅创建了螺旋矩阵,还可能通过某种方式将...

    在vc环境下c++实现螺旋矩阵的输出

    螺旋矩阵是一种特殊的矩阵,它的元素按照顺时针或者逆时针的方向螺旋式地填充。在C++编程中,实现螺旋矩阵的输出是一项基础且有趣的任务,尤其在VC(Visual C++)环境下,我们可以利用标准模板库(STL)以及基本的...

    l.rar_螺旋矩阵

    螺旋矩阵是一种特殊的二维数组,它的元素按照螺旋顺序填充。在创建螺旋矩阵时,通常从左上角开始,向右填充一行,然后向下填充一列,接着向左填充一行,再向上填充一列,如此反复,直到填满整个矩阵。这个过程可以...

    java 奇数阶幻方

    总的来说,Java实现奇数阶幻方涉及到数据结构(二维数组)、逻辑控制(填充算法)、数学计算(检查和调整)以及可视化展示(可能的图片输出)。这是一种很好的结合了编程和数学思维的练习,对于提升编程技巧和理解...

    输出回旋矩阵(c语言)

    在C语言中,我们可以使用二维数组来表示矩阵。比如,一个n×n的矩阵可以用一个一维数组的指针来表示,其中每个元素又是一个一维数组,代表矩阵的一行。定义矩阵时,我们通常需要声明一个大小为n*n的数组。 下面是一...

    JavaScript定义及输出螺旋矩阵的方法详解

    螺旋矩阵是一种特殊的矩阵,它的元素按照顺时针或逆时针的方向从外向内螺旋式地填充。在JavaScript中,我们可以使用对象和原型方法来创建一个功能,用于生成和输出这种螺旋矩阵。以下是对螺旋矩阵及其JavaScript实现...

    内螺旋矩阵算法

    内螺旋矩阵算法是一种在二维数组中填充数字的特殊方式,其特点是数字按顺时针方向从数组中心向外螺旋式地填充。这种填充模式在数据结构和算法的学习中颇为有趣,因为它涉及到了数组的操作以及对角线元素的处理。在...

    实验六第三题.docx

    3. 定义一个二维数组`arr[6][6]`,用来存储生成的螺旋矩阵。 4. 初始化两个变量`i`, `j`, 和 `k`,其中`i`和`j`用于遍历数组,`k`用于记录当前应填入的数值。 5. 使用两层嵌套的`for`循环来填充数组。外层循环`for...

    76道高难度编程题,C++入门基础,必编!

    3. **输出矩阵**:打印填充后的二维数组。 ### 知识点七:字符串处理 #### 题目描述 编写程序,处理一段文本,统计其中特定字符的出现次数。 #### 解析 1. **读取文本**:接收输入的文本字符串。 2. **字符计数**...

    C语言解决螺旋矩阵算法问题的代码示例

    在C语言中,解决螺旋矩阵问题通常涉及到二维数组的操作。这个问题的主要目标是将一个给定大小的矩阵(例如,6x6)填充上从1到矩阵元素总数的连续整数,并按螺旋顺序打印出来。 下面我们将详细探讨如何实现螺旋矩阵...

    螺旋矩阵源码_VB.NET

    例如,一个二维数组Array(,)可以用于存储矩阵的元素。初始化、赋值和遍历数组是实现螺旋矩阵的基础。 4. **循环控制**: 实现螺旋矩阵通常需要嵌套循环,如For...Next循环,用来遍历行和列。外层循环控制层数,内...

    c++ 螺旋方针

    螺旋数组是指一个二维数组按照螺旋形式填充数字的方式。通常情况下,我们会从数组的一个角落(如左上角)开始,按照顺时针或者逆时针方向填充数字。本案例中的“螺旋方针”就是一种顺时针填充的方法。 ### 二、螺旋...

    Python实现打印螺旋矩阵功能的方法

    在二维数组中,这种模式需要按照顺时针或逆时针方向填充元素,并在每层向内缩小填充范围。本文将深入探讨如何使用Python编程语言实现打印螺旋矩阵的功能,并讨论其核心概念与算法实现。 首先,让我们简单回顾螺旋...

    Spiral.zip_数学计算_C/C++_

    螺旋矩阵是一种特殊的二维数组,其元素按照顺时针或逆时针方向螺旋式填充。 在C/C++编程中,实现螺旋矩阵通常涉及以下几个关键知识点: 1. **二维数组**:首先,你需要理解如何声明和操作二维数组。在C/C++中,二...

    220个经典C程序源码文件,可以做为你的学习设计参考.zip

    014 求解二维数组的最大/最小元素 015 利用数组求前n个质数 016 编制万年历 017 对数组元素排序 018 任意进制数的转换 019 判断回文数 020 求数组前n元素之和 021 求解钢材切割的最佳订单 022 通过指针比较...

Global site tag (gtag.js) - Google Analytics