Java 如何用二維數組創建空心菱形
如何用二維數組創建空心菱形
提供一個我自己的實現方法,方法實現隻是一個人的是靠方式,並不是代表實力,真正的實力用自己的這種思維解決別人亟待解決的問題,真才是目前我覺得的編程的意義。雞湯喝瞭,精神好瞭!來看看我的實例。
題目:用“*”創建一個菱形空心
為瞭能更好的找出橫縱坐標的關系,我簡單做瞭一個菱形圖
圖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); } }
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- 新手初學Java流程控制
- 在Java中Scanner的用法總結
- Java基礎入門語法–String類
- java編程學習輸入輸出詳解看完快速上手
- Java Scanner的使用和hasNextXXX()的用法說明