Java實(shí)現(xiàn)順時(shí)針輸出螺旋二維數(shù)組的方法示例
最近看到一道有點(diǎn)意思的邏輯算法題,便著手實(shí)現(xiàn)一下。題目是要求打印 出N*N順時(shí)針螺旋數(shù)組,規(guī)律如下:
// 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
Java 實(shí)現(xiàn)示例代碼如下:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
int[][] rect = new int[n + 1][n + 1];
int x = 0, y = 1; // 當(dāng)前遍歷的位置
int px = 1, py = 0; // x/y 在當(dāng)前循環(huán)方向的增量
int pn = n; // 該方向上還需要多少個(gè)數(shù)字(會(huì)遞減,因?yàn)轫槙r(shí)針往里縮)
int sum = n; // 當(dāng)前遍歷方向的終點(diǎn)位置
/** 目標(biāo)輸出順時(shí)針 */
// 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
/** 翻轉(zhuǎn)矩陣為逆時(shí)針(為了便于后面邏輯處理,輸出的時(shí)候再翻轉(zhuǎn)回去) */
// 1 16 15 14 13
// 2 17 24 23 12
// 3 18 25 22 11
// 4 19 20 21 10
// 5 6 7 8 9
for (int i = 1; i <= n * n; i++) { // 翻轉(zhuǎn)矩陣循環(huán)
// 移到下一個(gè)點(diǎn)(第一次方向1->5 x增量為1, y的增量為0, 第二次方向?yàn)?->9,x增量為0,y增量為1,pn減少一個(gè))
x += px;
y += py;
rect[x][y] = i;
if (i == sum) { // 到達(dá)該方向的最后一個(gè)點(diǎn)
if (px == 1 || px == -1) { // x的增量不為0,則為豎向 -> 橫向
pn = pn - 1; // 豎向變?yōu)闄M向的時(shí)候,該方向上數(shù)字的個(gè)數(shù)會(huì)減少一個(gè)
sum = sum + pn;
py = px;
px = 0;
} else { // x的增量為0, y的增量不為0,則為橫向 -> 豎向
sum = sum + pn;
px = -py;
py = 0;
}
}
}
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n; j++) {
System.out.print(rect[j][i] + "\t"); // 翻轉(zhuǎn)復(fù)原輸出
}
System.out.println();
}
}
}
輸出測(cè)試

總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家學(xué)習(xí)或者使用java能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
IDEA中Web項(xiàng)目控制臺(tái)亂碼的問題及解決方法
這篇文章主要介紹了IDEA中Web項(xiàng)目控制臺(tái)亂碼的問題及解決方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
使用maven插件對(duì)java工程進(jìn)行打包過程解析
這篇文章主要介紹了使用maven插件對(duì)java工程進(jìn)行打包過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
深入了解Springboot核心知識(shí)點(diǎn)之?dāng)?shù)據(jù)訪問配置
這篇文章主要為大家介紹了Springboot核心知識(shí)點(diǎn)中的數(shù)據(jù)訪問配置,文中的示例代碼講解詳細(xì),對(duì)我們了解SpringBoot有一定幫助,快跟隨小編一起學(xué)習(xí)一下吧2021-12-12
IDEA使用Gradle構(gòu)建SpringBoot項(xiàng)目工程的詳細(xì)教程
這篇文章主要介紹了IDEA使用Gradle構(gòu)建SpringBoot項(xiàng)目工程的教程詳解,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
在win10系統(tǒng)下,如何配置Spring Cloud alibaba Seata以及出現(xiàn)問題時(shí)怎么解決
今天教大家如何在win10系統(tǒng)下,配置Spring Cloud alibaba Seata以及出現(xiàn)問題時(shí)怎么解決,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06
SpringBoot基于Shiro處理ajax請(qǐng)求代碼實(shí)例
這篇文章主要介紹了SpringBoot基于Shiro處理ajax請(qǐng)求代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06

