[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 复制代码
*
**
* *
****
*   *
**  **
* * * *
********
*       *
**      **
* *     * *
****    ****
*   *   *   *
**  **  **  **
* * * * * * * *
****************
*               *
**              **
* *             * *
****            ****
*   *           *   *
**  **          **  **
* * * *         * * * *
********        ********
*       *       *       *
**      **      **      **
* *     * *     * *     * *
****    ****    ****    ****
*   *   *   *   *   *   *   *
**  **  **  **  **  **  **  **
* * * * * * * * * * * * * * * *
********************************
*                               *
**                              **
* *                             * *
****                            ****
*   *                           *   *
**  **                          **  **
* * * *                         * * * *
********                        ********
*       *                       *       *
**      **                      **      **
* *     * *                     * *     * *
****    ****                    ****    ****
*   *   *   *                   *   *   *   *
**  **  **  **                  **  **  **  **
* * * * * * * *                 * * * * * * * *
****************                ****************
*               *               *               *
**              **              **              **
* *             * *             * *             * *
****            ****            ****            ****
*   *           *   *           *   *           *   *
**  **          **  **          **  **          **  **
* * * *         * * * *         * * * *         * * * *
********        ********        ********        ********
*       *       *       *       *       *       *       *
**      **      **      **      **      **      **      **
* *     * *     * *     * *     * *     * *     * *     * *
****    ****    ****    ****    ****    ****    ****    ****
*   *   *   *   *   *   *   *   *   *   *   *   *   *   *   *
**  **  **  **  **  **  **  **  **  **  **  **  **  **  **  **
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
****************************************************************
*                                                               *
**                                                              **
* *                                                             * *
****                                                            ****
*   *                                                           *   *
**  **                                                          **  **
* * * *                                                         * * * *
********                                                        ********
*       *                                                       *       *
**      **                                                      **      **
* *     * *                                                     * *     * *
****    ****                                                    ****    ****
*   *   *   *                                                   *   *   *   *
**  **  **  **                                                  **  **  **  **
* * * * * * * *                                                 * * * * * * * *
相关推荐
databook2 天前
用SymPy自动计算抛物线求根、判别式与顶点
python·数学·动效
Hali_Botebie2 天前
点积(Dot Product)和叉积(Cross Product)
数学
aWty_4 天前
实分析入门(12)--可测函数
学习·数学·算法·实变函数
databook4 天前
一次函数图像工厂:用 SymPy 自动生成 y=kx+b 对比动画
python·数学·动效
装不满的克莱因瓶5 天前
图像尺寸调整:缩放矩阵如何改变像素坐标?
人工智能·线性代数·数学·算法·机器学习·矩阵
闻缺陷则喜何志丹5 天前
【几何】指定半径倒角的实现,暂不考虑误差
数学·计算几何·几何·倒角
装不满的克莱因瓶5 天前
什么是特征分解?从数学定义到现实问题的映射
人工智能·数学·算法·机器学习·ai·特征分解
aWty_5 天前
实分析入门(11)--Cantor三分集
学习·数学·算法·实变函数
databook6 天前
用 SymPy 解决 Manim 曲线绘制速度不均的问题
python·数学·动效
Luhui Dev8 天前
大角几何 MCP 服务上线:让 AI Agent 直接完成几何作图
人工智能·数学·机器学习·大角几何·luhuidev