想到了一个经典的面试题,打印金字塔模型。比如
输入1,打印如下图案:
*
输入2,打印如下图案:
输入3,打印如下图案:
输入5,打印如下图案:
输入7,打印如下图案:
看了下网上有的写法,感觉挺复杂的。这里我自己原创了一种新写法,思路就是:把每一行都看成一个String对象,有几行就会有几个String对象。然后把这些对象存入list中,再遍历list,注意同时打印空格就好,代码如下:
import java.util.ArrayList;
import java.util.List;
public class Test01 {
public static void main(String[] args) {
jzt(9);
}
public static void jzt(int num) {
List<StringBuffer> list = new ArrayList<>();
for(int i=0;i<num;i++) {
StringBuffer sb = new StringBuffer();
for(int j=0;j<2*i+1;j++) {
sb.append("*");
}
list.add(sb);
}
for(int i=0;i<list.size();i++) {
for(int j=0;j<list.size()-i-1;j++) {
System.out.print(" ");
}
System.out.println(list.get(i));
}
}
}
测试结果看起来也没有什么问题,感觉效率比三层嵌套循环要高,而且更简洁,更好理解,欢迎大家指正。
原文:https://www.cnblogs.com/lisey/p/10770928.html