[Java] 展示杨辉三角中数字的奇偶性

我看了一个介绍分形和杨辉三角的视频,其中提到了杨辉三角中数字的奇偶性,联想到奇偶性和布尔运算有密切联系,于是写了点代码来展示杨辉三角中数字的奇偶性。

杨辉三角中的每个数字 n u m num num 都等于它左上角的数字 L L L 和右上角数字 R R R 的和(如果一个数字左上角没有数字或者右上角没有数字,那么这个数字的值为 1 \text{1} 1)。如果我们只关注数字的奇偶性,那么可以这样分析 ⬇️ (下表的分析仅针对 L L L 和 R R R 都存在的情况)

L L L 是否为奇数 R R R 是否为奇数 n u m = L + R num=L+R num=L+R 是否为奇数

至于边界值(即左上角没有数字或者右上角没有数字的那些数字)的处理,我们可以在数组中多存放 2 2 2 个元素。如果杨辉三角中某一行有 k k k 个数字,那么我们就用有 k + 2 k+2 k+2 个元素的 b o o l e a n boolean boolean 数组来保存各个数字的奇偶性(这样判定下一行各个数字的奇偶性时,会很好处理)。在此基础上,可以写出这样的代码 ⬇️

java 复制代码
public class Analyzer {

    public void displayRow(boolean[] currValues, int n) {
        for (int i = 1; i <= n; i++) {
            System.out.print(currValues[i] ? '*' : ' ');
        }
        System.out.println();
    }

    public void analyze(int bound) {
        int n = 1;
        // currValues[0] and currValues[len - 1] are always false
        boolean[] currValues = new boolean[]{false, true, false};
        while (true) {
            displayRow(currValues, n);
            if (++n == bound) {
                break;
            }
            currValues = calcNextValues(currValues, n);
        }
    }

    private boolean[] calcNextValues(boolean[] currValues, int n) {
        boolean[] nextValues = new boolean[n + 2];
        for (int i = 1; i <= n; i++) {
            nextValues[i] = currValues[i - 1] != currValues[i];
        }
        return nextValues;
    }

    public static void main(String[] args) {
        new Analyzer().analyze(80);
    }
}

请将以上代码保存为 Analyzer.java。运行如下命令就可以编译 Analyzer.java

bash 复制代码
javac Analyzer.java

运行如下命令可以运行 Analyzer 中的 main 方法。

bash 复制代码
java Analyzer

在我电脑上的运行结果如下 ⬇️ (* 表示这个位置的数字是奇数,空格表示这个位置的数字是偶数)

text 复制代码
*
**
* *
****
*   *
**  **
* * * *
********
*       *
**      **
* *     * *
****    ****
*   *   *   *
**  **  **  **
* * * * * * * *
****************
*               *
**              **
* *             * *
****            ****
*   *           *   *
**  **          **  **
* * * *         * * * *
********        ********
*       *       *       *
**      **      **      **
* *     * *     * *     * *
****    ****    ****    ****
*   *   *   *   *   *   *   *
**  **  **  **  **  **  **  **
* * * * * * * * * * * * * * * *
********************************
*                               *
**                              **
* *                             * *
****                            ****
*   *                           *   *
**  **                          **  **
* * * *                         * * * *
********                        ********
*       *                       *       *
**      **                      **      **
* *     * *                     * *     * *
****    ****                    ****    ****
*   *   *   *                   *   *   *   *
**  **  **  **                  **  **  **  **
* * * * * * * *                 * * * * * * * *
****************                ****************
*               *               *               *
**              **              **              **
* *             * *             * *             * *
****            ****            ****            ****
*   *           *   *           *   *           *   *
**  **          **  **          **  **          **  **
* * * *         * * * *         * * * *         * * * *
********        ********        ********        ********
*       *       *       *       *       *       *       *
**      **      **      **      **      **      **      **
* *     * *     * *     * *     * *     * *     * *     * *
****    ****    ****    ****    ****    ****    ****    ****
*   *   *   *   *   *   *   *   *   *   *   *   *   *   *   *
**  **  **  **  **  **  **  **  **  **  **  **  **  **  **  **
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
****************************************************************
*                                                               *
**                                                              **
* *                                                             * *
****                                                            ****
*   *                                                           *   *
**  **                                                          **  **
* * * *                                                         * * * *
********                                                        ********
*       *                                                       *       *
**      **                                                      **      **
* *     * *                                                     * *     * *
****    ****                                                    ****    ****
*   *   *   *                                                   *   *   *   *
**  **  **  **                                                  **  **  **  **
* * * * * * * *                                                 * * * * * * * *
相关推荐
Sunsets_Red1 天前
ABC462D 题解
c++·数学·编程·比赛·atcoder·信息学竞赛·信息学
databook2 天前
用SymPy自动因式分解:从面积拼图到代数恒等式
python·数学·动效
铸人2 天前
关于零的一些讨论
数学·极限·复数
装不满的克莱因瓶3 天前
自动微分的原理:计算图与前向传播
人工智能·pytorch·python·数学·ai·微积分·计算图
闻缺陷则喜何志丹3 天前
【解析几何丘维声 第一章】向量代数第二部分
数学·向量·计算几何·点乘·叉乘
装不满的克莱因瓶4 天前
掌握多头自注意力机制(Multi-Head Self-Attention)——Transformer 强大表达能力的核心来源
人工智能·python·深度学习·数学·ai·transformer
Samson Bruce4 天前
【初高中数学】
线性代数·数学·算法·机器学习
装不满的克莱因瓶5 天前
链式法则如何传递参数误差 —— 深入理解神经网络中的梯度传播
人工智能·python·深度学习·神经网络·数学·机器学习·ai
databook5 天前
用SymPy自动求解追及问题的方程
python·数学·动效
书中玉6 天前
2026高考一卷数学最后一问19题详细解答(含思路)
数学·考试·高考·2026年·最后一题·压轴题