按照你的要求加詳細(xì)注釋的圣誕樹Java程序如下:(編程思想在注釋中說明)
創(chuàng)新互聯(lián)專注于企業(yè)全網(wǎng)整合營(yíng)銷推廣、網(wǎng)站重做改版、柘城網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5網(wǎng)站設(shè)計(jì)、成都商城網(wǎng)站開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為柘城等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
public?class?ShengDanShu2?{
//這個(gè)程序的編程思想是利用對(duì)for循環(huán)變量i的控制達(dá)到一層循環(huán)代替雙層循環(huán)的目的
public?static?void?main(String[]?args)?{????
int???n=5;???//初始化打印圣誕樹層數(shù)變量n
int???a=0;???//初始化打印前置空格數(shù)變量a
int???b=0;???//初始化打印星號(hào)數(shù)變量b
for(int?i=1;i?=n;i++){???//打印n層圣誕樹
if(a!=(n-i)){????//如果前置空格數(shù)不等于n-i
System.out.print("?");?//打印一個(gè)空格
a++;????//前置空格數(shù)加一???
i=i-1;????//i變量減一??目的是固定住i變量不變直到a==n-i
}else?if(b!=(2*i-1)){???//如果星號(hào)數(shù)不等于2*i-1
System.out.print("*");??//打印一個(gè)星號(hào)
b++;????//星號(hào)數(shù)加一
i=i-1;???//i變量減一??目的是固定住i變量不變直到b==2*i-1
}else?if(a==(n-i)??b==(2*i-1)){//當(dāng)以上兩個(gè)條件都滿足時(shí),換行初始化a和b為0???
System.out.println();??//打印換行?
a=0;???//對(duì)新的一行重新初始化前置空格數(shù)變量a
b=0;??//對(duì)新的一行重新初始化打印星號(hào)數(shù)變量b
//這里沒有控制for循環(huán)的i變量減一,因?yàn)檫@時(shí)i變量加一,開始新一行。
}???
}???
}?????
}
運(yùn)行結(jié)果:
*
***
*****
*******
*********
朋友 你說的最好一句話我沒明白?
你能具體說下嗎?最好弄個(gè)圖片。
我跟你說一下思路:就是用for循環(huán)就可以.
---給你答案 供你參考,倉(cāng)促寫的:
public class ChristmasTree {
int x = 2;
int i = 0;
public void tree() {
for(i=0; i3; i++) {
for(int j=x; j=0; j--) {
System.out.print(" ");
}
x--;
for(int k=0; k=i; k++) {
System.out.print("*"+" ");
}
System.out.println();
}
}
public static void main(String args[]) {
new ChristmasTree().tree();
}
}
打印 * 號(hào)的時(shí)候不要用println,用print就行了
println是打印后換行,print則是直接打印