朋友 你說的最好一句話我沒明白?
望謨ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!
你能具體說下嗎?最好弄個圖片。
我跟你說一下思路:就是用for循環(huán)就可以.
---給你答案 供你參考,倉促寫的:
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();
}
}
按照你的要求加詳細(xì)注釋的圣誕樹Java程序如下:(編程思想在注釋中說明)
public?class?ShengDanShu2?{
//這個程序的編程思想是利用對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;???//初始化打印星號數(shù)變量b
for(int?i=1;i?=n;i++){???//打印n層圣誕樹
if(a!=(n-i)){????//如果前置空格數(shù)不等于n-i
System.out.print("?");?//打印一個空格
a++;????//前置空格數(shù)加一???
i=i-1;????//i變量減一??目的是固定住i變量不變直到a==n-i
}else?if(b!=(2*i-1)){???//如果星號數(shù)不等于2*i-1
System.out.print("*");??//打印一個星號
b++;????//星號數(shù)加一
i=i-1;???//i變量減一??目的是固定住i變量不變直到b==2*i-1
}else?if(a==(n-i)??b==(2*i-1)){//當(dāng)以上兩個條件都滿足時,換行初始化a和b為0???
System.out.println();??//打印換行?
a=0;???//對新的一行重新初始化前置空格數(shù)變量a
b=0;??//對新的一行重新初始化打印星號數(shù)變量b
//這里沒有控制for循環(huán)的i變量減一,因為這時i變量加一,開始新一行。
}???
}???
}?????
}
運行結(jié)果:
*
***
*****
*******
*********
把for-j循環(huán)for(int j=1;j=height-1;j++)改成for(int j=1;j=height-i;j++)
即j=height-1;改成j=height-i;
完整的Java程序如下:
import?java.util.Scanner;
public?class?ShengDanShu?{
public?static?void?main(String[]?args)?{
int?height;//樹的高度
Scanner?in?=?new?Scanner(System.in);
System.out.println("請輸入樹的高度");
height?=?in.nextInt();
for(int?i=1;i=height;i++)
{
//首先輸出前面的空格
for(int?j=1;j=height-i;j++)
{
System.out.print("?");
}
//輸出*
for(int?k=1;k=2*i-1;k++)
{
System.out.print("*");
}
System.out.println();
}
}
}
運行結(jié)果:
請輸入樹的高度
6
*
***
*****
*******
*********
***********