首頁 > 軟體

Java 如何用二維陣列建立空心菱形

2022-03-02 16:00:20

如何用二維陣列建立空心菱形

提供一個我自己的實現方法,方法實現只是一個人的是靠方式,並不是代表實力,真正的實力用自己的這種思維解決別人亟待解決的問題,真才是目前我覺得的程式設計的意義。雞湯喝了,精神好了!來看看我的範例。

題目:用“*”建立一個菱形空心

為了能更好的找出橫縱座標的關係,我簡單做了一個菱形圖

圖1.菱形

從圖中可以找出*點與座標值的意義,所以此題是用二維座標來做的;

分兩部分輸出影象, 上半部分:

從中間開花,給兩邊的值賦值為1,否則為0,最後給賦值為1的點輸出*號;

  • 定義二維陣列的位 int []a=new int [13][13];
  • 定義列方向上的兩個點,p1,p2,即a[i][p1],a[i][p2];  

所以由圖2,可知   A ,B,C點可以知道p1=a.length/2-i(在程式設計過程中i是0,a.length/2是6也是一行中的中點),p2=a.length/2+i; B(i,p1),C(i,p2);

圖2.菱形

為什麼分兩部分,因為在a.lengh/2-i  ,在i等於7的時候得負了,所以並不能一直使用原來的p1,p2的值,需要重新找好橫縱座標的規律。

下半部分:

D的座標是(i,i-a.length/2),即D(i,p3),E的座標比較難找到關係,我也是想了很久,呵呵就是一直試,最後沒辦法試不出來,還是畫圖做分析才找到規律的,所以科學的方法是要用數學的思維,找橫縱座標點的位置關係;

圖3 E點座標分析

具體實現程式碼:

package com.JavaBase; 
public class lingxing {
	// 菱形
 
	public static void main(String[] args) {
		int n = 15;//n只能是奇數
		int[][] a = new int[n][n];
		for (int i = 0; i < a.length; i++) {
			for (int j = 0; j < a[i].length; j++) {
				a[i][j] = 0;
				int p1 = a.length / 2 - i;
				int p2 = a[i].length / 2 + i;//p1,p2的規律非常好找
				if (i <= a.length / 2) {//上半部分
					a[i][p1] = 1;
					a[i][p2] = 1;
					if (a[i][j] == 1) {
						System.out.print("*");
					} else {
						System.out.print(" ");
					}
				} else {//下半部分
					int p3 = i - a.length / 2;//與p1相反
					int p4 = a.length - (i - a.length / 2) - 1;//p4的規律比較難找到
					a[i][p3] = 1;
					a[i][p4] = 1;
					if (a[i][j] == 1) {
						System.out.print("*");
					} else {
						System.out.print(" ");
					}
				}
			}
			System.out.println();
		}
	}
}

 給予借鑑和思考,方法有很多,不單隻有這種,也許你的改進之後會更好。

使用陣列列印實心菱形

輸出如圖所示的影象

思路建立一個二維方形陣列,寫出正方形的四個角,之後用stringbuffer中的append進行替換

知識點:

輸入Scanner sc = new Scanner(System.in);  想要轉換成int數要  int num =sc.nextInt();

二維陣列的輸出(其中一種方法)

for(int i=0;i<array.length;i++)  
	     {  
	         for(int j=0;j<array[i].length;j++)  
	         {  
	             System.out.print(array[i][j]+" ");  
	         }  
	         System.out.println();  //換行  
	     }  

正式程式碼

import java.util.Scanner; 
public class text_2 {
	public static void main(String[] args){
		System.out.println("請輸入陣列維度");
		Scanner sc = new Scanner(System.in);
		int num =sc.nextInt();
		text_2.printstart(num);			
	}
	public static void printstart(int n){
		int[][] array = new int[n][n];
		for (int row = 0;row<n/2;row++){
			for(int line = 0;line <(n/2-row);line++){
				array[row][line]=1;
				array[row][n-line-1]=1;
				array[n-row-1][line]=1;
				array[n-row-1][n-line-1]=1;
			}
		}
		for(int i=0;i<array.length;i++)  
	     {  
	         for(int j=0;j<array[i].length;j++)  
	         {  
	             System.out.print(array[i][j]+" ");  
	         }  
	         System.out.println();  //換行  
	     }  
		for(int row=0;row<n;row++){
			StringBuilder column = new StringBuilder();
			for(int line= 0;line<n;line++){
				if(array[row][line]==1){
					column.append("  ");
				}else{
					column.append("*");
				}
			}System.out.println(column);
		}
	}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com