Java實現螺旋矩陣


螺旋矩陣是指一個呈螺旋狀的矩陣,它的數字由第一行開始到右邊不斷變大,向下變大,
向左變大,向上變大,如此循環。如下圖,

故,實現螺旋矩陣的思路也就跟上圖所示,依次從外層向里層循環,當n為偶數時,循環n/2次;n為奇數時,循環n/2+1次。具體實現看以下代碼:

import java.util.Scanner;


public class Snake {
	
	public void snake(int n)
	{
		int[][] data = new int[n][n];
		int intA;
		int value = 1;
		if(n % 2 != 0)       //奇數循環n/2+1次
		{
			intA = n/2 + 1;
		}else{
			intA = n/2;      //偶數循環n/2次
		}
		
		for(int i = 0; i < intA; i++)  //從外向里循環
		{
			//從左到右循環
			for(int j = i; j < n - i; j++)  
			{
				data[i][j] = value++;
			}
			
			//右列從上向下循環
			for(int k = i + 1; k < n - i; k++)
			{
				data[k][n-i-1] = value++;
			}
			
			//從右到左
			for(int l = n-i-2; l >= i; l--)
			{
				data[n-i-1][l] = value++;
			}
			
			//從下到上
			for(int m = n - i - 2; m > i; m--)
			{
				data[m][i] = value++;
			}
		}
		
		for(int i = 0; i < n; i++) //遍歷輸出
		{
			for(int j = 0; j < n; j++)
			{
				System.out.print(data[i][j]+" ");
			}
			System.out.println();
		}
	}
 
    public static void main(String[] args) {
    	Scanner sin = new Scanner(System.in);
    	Snake sn = new Snake();
    	while(sin.hasNextInt())
    	{
    		int n = sin.nextInt();
    		sn.snake(n);
    	}
    }
}

  測試結果:

5
1 2 3 4 5
16 17 18 19 6
15 24 25 20 7
14 23 22 21 8
13 12 11 10 9


6
1 2 3 4 5 6
20 21 22 23 24 7
19 32 33 34 25 8
18 31 36 35 26 9
17 30 29 28 27 10
16 15 14 13 12 11


3
1 2 3
8 9 4
7 6 5
4
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7


9
1 2 3 4 5 6 7 8 9
32 33 34 35 36 37 38 39 10
31 56 57 58 59 60 61 40 11
30 55 72 73 74 75 62 41 12
29 54 71 80 81 76 63 42 13
28 53 70 79 78 77 64 43 14
27 52 69 68 67 66 65 44 15
26 51 50 49 48 47 46 45 16
25 24 23 22 21 20 19 18 17

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM