java打印菱形及直角和等腰三角形的方法
本文講述如何用Java打印一個菱形,以及打印直角和等腰三角形的方法, 本文教程比較詳細,如果想要直接學習菱形可以直接翻到本文最下方!?。?/p>
左下角三角形
(這里說的方位均是對應矩形來說)
int a = 5; for (int i = 0; i < a; i++) { for (int j = 0; j < i; j++) { System.out.print("*"); } System.out.println(); }
這段代碼將輸出如下圖形,,其中i<?控制輸出行數(shù),j<?控制輸出列數(shù)
這里j<i,且關于j的循環(huán)嵌套在關于i的遞增循環(huán)里,所以列數(shù)(也是每行的數(shù)量)會隨著行數(shù)的增加而增加,最終形成一個左下角方位的三角形
(這里輸出*號語句要用System.out.print();避免換行。最下面的 System.out.println()是起換行作用; )
右下角三角形
int a = 5; for (int i = 0; i <= a; i++) { for (int k = a; k > i; k--) { System.out.print(" "); } for (int j = 0; j < i; j++) { System.out.print("*"); } System.out.println(); }
這段代碼將輸出如下圖形,這里增加了一個關于k的for循環(huán),它的作用是在原本左下角的基礎上在每行輸出的*號之前增加空格,注意這里輸出空格同樣使用System.out.print();避免換行,因為k的循環(huán)是k--的遞減循環(huán),所以從i開始遞減輸出空格,就會形成一盒右下角的三角形。
正等腰三角形
int a = 5; for (int i = 0; i <= a; i++) { for (int k = a; k > i; k--) { System.out.print(" "); } for (int j = 0; j < 2*i-1; j++) { System.out.print("*"); } System.out.println(); }
這段代碼將輸出如下結果,觀察下面的實際輸出圖片就會發(fā)現(xiàn)其實很好理解,只是將原來的右下角三角形輸出的*號改為了1、3、5、7、9的奇數(shù)排列,我們可以利用規(guī)律,將控制每行數(shù)量的j改為2*i-1實現(xiàn),同理利用不同公式可以控制每行的數(shù)量。
實際全部輸出為
這里我們已經(jīng)解決了菱形的上半部分
左上角三角形
int a =5 ; for (int i = 0; i < a; i++) { for (int j = a; j > i; j--) { System.out.print("*"); } System.out.println(); }
這段代碼將輸出如下結果,左上角就是倒過來打印左下角三角形,所以只需要讓每行的*號遞減即可,所以只用改變關于j的循環(huán)就可,讓其初始值為最大,并將迭代器改為j--就可以實現(xiàn)此效果
右上角三角形
int len =5 ; for (int i = 0; i < len; i++) { for (int k = 0; k < i; k++) { System.out.print(" "); } for (int j = len; j > i; j--) { System.out.print("*"); } System.out.println(); }
這段代碼講輸出如下結果,這與左下三角和右下三角的本質相似,就是在輸出的*號前面增加空格,不過這里是倒敘輸出,那么相應輸出空格的程序也要反過來。
倒等腰三角形
int a =5 ; for (int i = a; i > 0; i--) { for (int k = a; k >= i; k--) { System.out.print(" "); } for (int j = 2*i-1; j > 0; j--) { System.out.print("*"); } System.out.println(); }
這段代碼將輸出如下結果,對比全部輸出內容,可以看到原理與正等腰三角類似,只是顛倒輸出順序,就不過多贅述這個問題了。
菱形
實際上菱形就是一正一反兩個三角形拼接而成,拆解過后,我們就知道可以通過輸出正反等腰三角形就可以組成菱形。
int a = 5; //正等腰三角形 for (int i = 0; i < a; i++) { for (int l = a; l > i; l--) { System.out.print(" "); } for (int j = 0; j < 2*i-1; j++) { System.out.print("*"); } System.out.println(); } //倒等腰三角形 for (int i = a-1; i > 0; i--) { for (int k = a; k >= i; k--) { System.out.print(" "); } for (int j = 2*i-3; j > 0; j--) { System.out.print("*"); } System.out.println(); }
這段代碼將輸出如下結果,兩個三角形輸出的原理上面有詳細解析,這里講需要注意的地方,
輸出下面的三角形的時候要將行數(shù)(即i的初始值)減去1,因為菱形中間的轉折線要比上下兩邊都長,我們已經(jīng)使用了上面的最長邊,下面的三角形就應該省略,減去1后在開始(也可以讓上面減少一次輸出)。
2.因為行數(shù)減1了,所以對應的輸出數(shù)量也要減掉,因為每行是增加2個,所以每一行輸出的數(shù)量都應該額外減去2,所以j的初始值應該是2i-3;
這就是利用java輸出一個菱形的方法,希望對大家有所幫助?。?!
總結
到此這篇關于java打印菱形及直角和等腰三角形的文章就介紹到這了,更多相關java打印菱形內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SpringBoot集成WebSocket【基于純H5】進行點對點[一對一]和廣播[一對多]實時推送
這篇文章主要介紹了SpringBoot集成WebSocket【基于純H5】進行點對點[一對一]和廣播[一對多]實時推送,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-08-08MyBatis-Plus通過version機制實現(xiàn)樂觀鎖的思路
version機制的核心思想就是,假設發(fā)生并發(fā)沖突的幾率很低,只有當更新數(shù)據(jù)的時候采取檢查是否有沖突,而判斷是否有沖突的依據(jù)就是version的值是否被改變了,這篇文章主要介紹了MyBatis-Plus通過version機制實現(xiàn)樂觀鎖的思路,需要的朋友可以參考下2021-09-09