废话不多讲,直接暴力循环,去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。
打印空格或者“_”,可以得到是最大高度减去当前所在高度的差。
根据这两个规律我们可以用代码实现了。