亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java編程實(shí)現(xiàn)打印螺旋矩陣實(shí)例代碼

 更新時(shí)間:2017年12月13日 16:33:46   作者:purelife  
這篇文章主要介紹了Java編程實(shí)現(xiàn)打印螺旋矩陣實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下。

直接上代碼吧。

昨晚騰訊在線測試遇到的題。

螺旋矩陣是指一個(gè)呈螺旋狀的矩陣,它的數(shù)字由第一行開始到右邊不斷變大,向下變大,向左變大,向上變大,如此循環(huán)。

import java.util.Scanner;
public class mysnakematrix {
	private int n;
	//
	private int a[][];
	// 聲明一個(gè)矩陣
	private int value = 1;
	// 矩陣?yán)飻?shù)字的值
	public mysnakematrix(int i) {
		this.n = i;
		a = new int[n][n];
	}
	// 計(jì)算第m層左上角的數(shù)字
	private int getcorner(int m) {
		int corner = 1;
		int o = n - 1;
		for (int i = 0; i < m - 1; ++i) {
			corner += 4 * o;
			o = o - 2;
		}
		return corner;
	}
	// 生成矩陣的每一層的每一邊的數(shù)
	// s表示4個(gè)方向,分別取值1,2,3,4,表示4個(gè)不同的方向。
	// o表示這條邊的起始值。
	// x表示第m層每條邊的數(shù)字個(gè)數(shù)
	private void side(int s, int o, int x, int m) {
		int i = 0;
		int j = 0;
		switch (s) {
			case 1:
			      i = m - 1;
			j = m - 1;
			for (int k = 0; k < x; ++k) {
				a[i][j + k] = value;
				++value;
			}
			break;
			case 2:
			      i = m - 1;
			j = m - 1 + x;
			for (int k = 0; k < x; ++k) {
				a[i + k][j] = value;
				++value;
			}
			break;
			case 3:
			      i = m - 1 + x;
			j = m - 1 + x;
			for (int k = 0; k < x; ++k) {
				a[i][j - k] = value;
				++value;
			}
			break;
			case 4:
			      i = m - 1 + x;
			j = m - 1;
			for (int k = 0; k < x; ++k) {
				a[i - k][j] = value;
				++value;
			}
			break;
		}
	}
	// 生成蛇形矩陣的第m層
	private void shell(int m)// m表示第m層
	{
		int x = n - 1 - (m - 1) * 2;
		// x表示第m層每條邊的數(shù)字個(gè)數(shù)
		int o = getcorner(m);
		int o1 = o;
		int o2 = o1 + x;
		int o3 = o2 + x;
		int o4 = o3 + x;
		// System.out.println(o4);
		side(1, o, x, m);
		side(2, o, x, m);
		side(3, o, x, m);
		side(4, o, x, m);
	}
	// 生成蛇形矩陣
	public void snakeMatrix() {
		int m = (n + 1) / 2;
		// 計(jì)算一共有多少層
		for (int i = 1; i <= m; ++i) {
			shell(i);
		}
		if (n % 2 == 1) {
			a[n / 2][n / 2] = n * n;
		}
	}
	// 打印矩陣
	public void print() {
		for (int i = 0; i < n; ++i) {
			for (int j = 0; j < n; ++j) {
				if (a[i][j] < 10) {
					System.out.print(a[i][j] + " ");
				} else {
					System.out.print(a[i][j] + " ");
				}
			}
			System.out.println();
		}
	}
	public static void main(String args[]) {
		mysnakematrix my = new mysnakematrix(new Scanner(System.in).nextint());
		//利用Scanner獲取控制臺輸入
		my.snakeMatrix();
		my.print();
	}
}

總結(jié)

以上就是本文關(guān)于Java編程實(shí)現(xiàn)打印螺旋矩陣實(shí)例代碼的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:

Java語言描述存儲結(jié)構(gòu)與鄰接矩陣代碼示例

Java編程實(shí)現(xiàn)鄰接矩陣表示稠密圖代碼示例

Java編程實(shí)現(xiàn)A*算法完整代碼

如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

相關(guān)文章

  • Eclipse中導(dǎo)入Maven Web項(xiàng)目并配置其在Tomcat中運(yùn)行圖文詳解

    Eclipse中導(dǎo)入Maven Web項(xiàng)目并配置其在Tomcat中運(yùn)行圖文詳解

    這篇文章主要介紹了Eclipse中導(dǎo)入Maven Web項(xiàng)目并配置其在Tomcat中運(yùn)行圖文詳解,需要的朋友可以參考下
    2017-12-12
  • SpringIOC控制反轉(zhuǎn)的原理詳解

    SpringIOC控制反轉(zhuǎn)的原理詳解

    這篇文章主要介紹了SpringIOC控制反轉(zhuǎn)的原理詳解,本來管理業(yè)務(wù)對象(bean)的操作是由我們程序員去做的,但是有了?Spring?核心容器后,這些?Bean?對象的創(chuàng)建和管理交給我們Spring容器去做了,也就是控制權(quán)由程序員變成了容器,需要的朋友可以參考下
    2023-08-08
  • 一文帶你了解SpringBoot的啟動(dòng)原理

    一文帶你了解SpringBoot的啟動(dòng)原理

    大家通常只需要給一個(gè)類添加一個(gè)@SpringBootApplication 注解,然后再加一個(gè)main 方法里面固定的寫法 SpringApplication.run(Application.class, args);那么spring boot 到底是如何啟動(dòng)服務(wù)的呢,接下來咱們通過源碼解析,需要的朋友可以參考下
    2023-05-05
  • Java詳細(xì)分析講解自動(dòng)裝箱自動(dòng)拆箱與Integer緩存的使用

    Java詳細(xì)分析講解自動(dòng)裝箱自動(dòng)拆箱與Integer緩存的使用

    裝箱就是把基本類型轉(zhuǎn)換成包裝類,拆箱就是把包裝類轉(zhuǎn)換成基本類型,下面這篇文章主要給大家介紹Java中自動(dòng)裝箱、自動(dòng)拆箱與Integer緩存,需要的朋友可以參考下
    2022-04-04
  • IntelliJ IDEA安裝目錄和設(shè)置目錄的說明(IntelliJ IDEA快速入門)

    IntelliJ IDEA安裝目錄和設(shè)置目錄的說明(IntelliJ IDEA快速入門)

    這篇文章主要介紹了IntelliJ IDEA安裝目錄和設(shè)置目錄的說明(IntelliJ IDEA快速入門),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • Spring?Boot?實(shí)現(xiàn)Redis分布式鎖原理

    Spring?Boot?實(shí)現(xiàn)Redis分布式鎖原理

    這篇文章主要介紹了Spring?Boot實(shí)現(xiàn)Redis分布式鎖原理,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下
    2022-08-08
  • SpringMvc+Mybatis+Pagehelper分頁詳解

    SpringMvc+Mybatis+Pagehelper分頁詳解

    這篇文章主要介紹了SpringMvc+Mybatis+Pagehelper分頁詳解,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下的相關(guān)資料
    2017-01-01
  • JVM的7種垃圾回收器(小結(jié))

    JVM的7種垃圾回收器(小結(jié))

    這篇文章主要介紹了JVM的7種垃圾回收器(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • Java?List排序4種寫法整理

    Java?List排序4種寫法整理

    這篇文章主要給大家介紹了關(guān)于Java?List排序4種寫法整理的相關(guān)資料,在有的時(shí)候我們會需要對List進(jìn)行排序,在Java中如何實(shí)現(xiàn)呢,本文記錄一下Java中對List的幾種排序方式,需要的朋友可以參考下
    2023-08-08
  • 使用@Transactional 設(shè)置嵌套事務(wù)不回滾

    使用@Transactional 設(shè)置嵌套事務(wù)不回滾

    這篇文章主要介紹了使用@Transactional 設(shè)置嵌套事務(wù)不回滾問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07

最新評論