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