在 Java 中,通过以下步骤生成螺旋数组:从左上角开始,向右移动直到行末。向下移动直到到达列末。向左移动直到到达行首。向上移动直到到达列首。重复 2-5 步骤,直到填满整个数组。实现了上述步骤的代码如下:public static int[][] generateSpiralMatrix(int n) { int[][] matrix = new int[n][n]; int count = 1; int row = 0, col = 0;

如何实现 Java 中的螺旋数组
螺旋数组是一种特殊类型的二维数组,其中元素以螺旋顺序排列。生成螺旋数组的算法如下:
步骤:
代码实现:
立即学习“Java免费学习笔记(深入)”;
<code class="java">import java.util.Arrays;
public class SpiralMatrix {
public static void main(String[] args) {
int[][] matrix = generateSpiralMatrix(5);
System.out.println(Arrays.deepToString(matrix));
}
public static int[][] generateSpiralMatrix(int n) {
int[][] matrix = new int[n][n];
int count = 1;
int row = 0, col = 0;
int dir = 0; // 0: right, 1: down, 2: left, 3: up
while (count <= n * n) {
matrix[row][col] = count++;
switch (dir) {
case 0:
if (col < n - 1 && matrix[row][col + 1] == 0) {
col++;
} else {
dir = 1;
row++;
}
break;
case 1:
if (row < n - 1 && matrix[row + 1][col] == 0) {
row++;
} else {
dir = 2;
col--;
}
break;
case 2:
if (col > 0 && matrix[row][col - 1] == 0) {
col--;
} else {
dir = 3;
row--;
}
break;
case 3:
if (row > 0 && matrix[row - 1][col] == 0) {
row--;
} else {
dir = 0;
col++;
}
}
}
return matrix;
}
}</code>以上就是java中螺旋数组怎么实现的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号