螺旋三角

简单的思路就是先分配存储空间,然后找规律,一个三角一个三角的往中心画,最后输出数组中的数据即可,话不多说,直接上代码

public static void trianglePrint(int num){
        int[][] array = new int[num][];
        for (int i = 0; i <num; i++) {
            array[i] = new int[num-i];
        }
        for (int k = 1; k <= num;k++) {
            int i, j;
            int temp = k / 3;
            int init = (2 * num - k + 2) * (k-1) / 2+1;
            switch (k%3){
                case 1:
                    i = temp;
                    j = temp;
                    for (int n = 0; n < num - k + 1; n++) {
                        array[i][j] = init + n;
                        j++;
                    }
                    break;
                case 2:
                    i = temp+1;
                    j = num - 2 * temp-2;
                    for (int n = 0; n < num - k+1; n++) {
                        array[i][j] = init + n;
                        i++;
                        j--;
                    }
                    break;
                case 0:
                    i = num - 2 * temp;
                    j = temp - 1;
                    for (int n = 0; n < num - k + 1; n++) {
                        array[i][j] = init + n;
                        i--;
                    }
                    break;
            }
        }
        for (int h = 0; h < num; h++) {
            int k = 0;
            for (; k <array[h].length-1; k++) {
                System.out.print(array[h][k]+"\t");
            }
            System.out.println(array[h][k]);
        }
    }
发布了26 篇原创文章 · 获赞 7 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/luffy_1993/article/details/104720120