您好,登录后才能下订单哦!
密码登录
            
            
            
            
        登录注册
            
            
            
        点击 登录注册 即表示同意《亿速云用户服务条款》
        # Java杨辉三角的实现方法是什么
杨辉三角(帕斯卡三角)是二项式系数在三角形中的几何排列,具有对称性和递推特性。在Java中实现杨辉三角可通过多种方法,本文将介绍三种典型实现方式。
## 一、基础二维数组法
```java
public class YangHuiTriangle {
    public static void main(String[] args) {
        int rows = 10;
        int[][] triangle = new int[rows][];
        
        for (int i = 0; i < rows; i++) {
            triangle[i] = new int[i + 1];
            triangle[i][0] = 1;
            triangle[i][i] = 1;
            
            for (int j = 1; j < i; j++) {
                triangle[i][j] = triangle[i-1][j-1] + triangle[i-1][j];
            }
        }
        
        // 打印结果
        for (int[] row : triangle) {
            System.out.println(Arrays.toString(row));
        }
    }
}
特点: - 直观体现杨辉三角的二维结构 - 时间复杂度:O(n²) - 空间复杂度:O(n²)
public class YangHuiTriangleOptimized {
    public static void main(String[] args) {
        int rows = 10;
        int[] currentRow = new int[rows];
        
        for (int i = 0; i < rows; i++) {
            currentRow[i] = 1;
            for (int j = i-1; j > 0; j--) {
                currentRow[j] += currentRow[j-1];
            }
            
            // 打印当前行
            for (int k = 0; k <= i; k++) {
                System.out.print(currentRow[k] + " ");
            }
            System.out.println();
        }
    }
}
优势: - 空间复杂度降至O(n) - 利用从后向前遍历避免数据覆盖
public class YangHuiRecursive {
    public static int getNumber(int row, int col) {
        if (col == 0 || col == row) {
            return 1;
        }
        return getNumber(row-1, col-1) + getNumber(row-1, col);
    }
    
    public static void main(String[] args) {
        int rows = 5;
        for (int i = 0; i < rows; i++) {
            for (int j = 0; j <= i; j++) {
                System.out.print(getNumber(i, j) + " ");
            }
            System.out.println();
        }
    }
}
注意事项: - 存在大量重复计算 - 适合小规模数据展示递归思想 - 实际应用需配合记忆化优化
实现三角形对齐输出:
// 在打印前添加空格
for (int s = 0; s < rows - i; s++) {
    System.out.print(" ");
}
| 方法 | 优点 | 缺点 | 
|---|---|---|
| 二维数组 | 直观易懂 | 空间占用大 | 
| 一维数组 | 空间效率高 | 逻辑稍复杂 | 
| 递归 | 代码简洁 | 性能差,易栈溢出 | 
根据实际需求选择合适实现方式,通常推荐使用优化后的一维数组法。 “`
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。