廢話不多講,直接暴力循環,去tm的性能優化。
例子:
Scanner scanner = new Scanner(System.in);
System.out.println("請輸入金字塔的高度");
int h = scanner.nextInt();
//i 爲當前打印高度
for(int i = 1;i<=h;i++){
//先打印每行的空格
int temp = h-i;
for(int j = 1;j <= temp;j++){
Thread.sleep(100);
System.out.print("_");
}
int num = 2*i -1;
//每行打印多少個符號 根據規律 應該得到一個等差數列 公差爲2 公式=2i-1
for(int j = 1; j <= num;j++){
Thread.sleep(200);
System.out.print("*");
}
for(int j = 1;j <= temp;j++){
Thread.sleep(100);
System.out.print("_");
}
System.out.println();
}
分析:
例如我們打印5行 h代表所在行高度,n代表每行需要打印*的個數。
____*____ h=1 n =1
___***___ h=2 n=3
__*****__ h=3 n=5
_*******_ h=4 n=7
********* h=5 n=9
可以觀察到打印*的個數只能整體來看成一個等差數列 公差爲 2,可以得到公式: 2h-1。
打印空格或者“_”,可以得到是最大高度減去當前所在高度的差。
根據這兩個規律我們可以用代碼實現了。