其他分享
首页 > 其他分享> > 打印"*"号三角形和杨辉三角形

打印"*"号三角形和杨辉三角形

作者:互联网

打印"*"号三角形和杨辉三角形

"*"号三角形

使用Java打印一个由" * "组成的三角形。

    public static void main(String[] args) {
        for(int i=1;i<=5;i++){
            for(int j=5;j>=i;j--){
                System.out.print(" ");
            }
            for(int j =1;j<=i;j++){
                System.out.print("*");
            }
            for(int j=1;j<i;j++){
                System.out.print("*");
            }
            System.out.println();
        }
    }

第一个嵌套循环输出的是三角形前面的空格。

第二个嵌套循环输出的是一半的三角形(多的那一部分,因为j是小于等于font>i),如图:

第三个嵌套输出的是另一半的三角形(少的那部分),如图(和第二个嵌套循环的输出合起来了):

杨辉三角形

其实要打印杨辉三角形和打印" * "号三角形有些类似,只要在打印" * "号三角形的基础上,稍微掌握再一点关于杨辉三角形的算法就可以了,只要知道杨辉三角形的两边数都是1(除了第一层),然后从第三层开始,除了两边的数以外的数都是上一层的前一个位的数加上本位的数,用数组就可以很好地实现,即arr [i] [j] = arr [i - 1] [j - 1] + arr [i - 1] [j];(arr是声明了的数组变量)。

public static void main(String[] args) {
        int[][] arr = new int[5][5];
        for (int i = 0; i < arr.length; i++) {
            for(int j= arr.length;j>=i;j--){
                System.out.print(" ");
            }
            for (int j = 0; j <= i; j++) {
                if (j == 0 || j == i) {
                    arr[i][j] = 1;
                } else {

                    arr[i][j] = arr[i - 1][j - 1] + arr[i - 1][j];
                }
                System.out.print(arr[i][j]+" ");
            }
            System.out.println();
        }
    }

效果图:

标签:arr,int,打印,嵌套循环,杨辉三角,三角形
来源: https://www.cnblogs.com/qinyu33/p/16560282.html