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

背景

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

正文

杨辉三角中的每个数字 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 是否为奇数

于是可以写出这样的代码 ⬇️

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 复制代码
*
**
* *
****
*   *
**  **
* * * *
********
*       *
**      **
* *     * *
****    ****
*   *   *   *
**  **  **  **
* * * * * * * *
****************
*               *
**              **
* *             * *
****            ****
*   *           *   *
**  **          **  **
* * * *         * * * *
********        ********
*       *       *       *
**      **      **      **
* *     * *     * *     * *
****    ****    ****    ****
*   *   *   *   *   *   *   *
**  **  **  **  **  **  **  **
* * * * * * * * * * * * * * * *
********************************
*                               *
**                              **
* *                             * *
****                            ****
*   *                           *   *
**  **                          **  **
* * * *                         * * * *
********                        ********
*       *                       *       *
**      **                      **      **
* *     * *                     * *     * *
****    ****                    ****    ****
*   *   *   *                   *   *   *   *
**  **  **  **                  **  **  **  **
* * * * * * * *                 * * * * * * * *
****************                ****************
*               *               *               *
**              **              **              **
* *             * *             * *             * *
****            ****            ****            ****
*   *           *   *           *   *           *   *
**  **          **  **          **  **          **  **
* * * *         * * * *         * * * *         * * * *
********        ********        ********        ********
*       *       *       *       *       *       *       *
**      **      **      **      **      **      **      **
* *     * *     * *     * *     * *     * *     * *     * *
****    ****    ****    ****    ****    ****    ****    ****
*   *   *   *   *   *   *   *   *   *   *   *   *   *   *   *
**  **  **  **  **  **  **  **  **  **  **  **  **  **  **  **
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
****************************************************************
*                                                               *
**                                                              **
* *                                                             * *
****                                                            ****
*   *                                                           *   *
**  **                                                          **  **
* * * *                                                         * * * *
********                                                        ********
*       *                                                       *       *
**      **                                                      **      **
* *     * *                                                     * *     * *
****    ****                                                    ****    ****
*   *   *   *                                                   *   *   *   *
**  **  **  **                                                  **  **  **  **
* * * * * * * *                                                 * * * * * * * *
相关推荐
金銀銅鐵7 小时前
[Python] 扩展欧几里得算法
python·数学·算法
金銀銅鐵10 小时前
n^5 和 n 的个位数是否总相等?
python·数学
金銀銅鐵14 小时前
借助 Pygame 探索最大公约数的规律
python·数学·游戏
金銀銅鐵5 天前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
金銀銅鐵8 天前
用 Pygame 实现 15 puzzle
python·数学·游戏
Luhui Dev11 天前
几何图,现在可以用 API 一句话生成
人工智能·数学·luhuidev
xcLeigh12 天前
数学之美:数字革命背后的底层逻辑
人工智能·数学·ai·数学原理·书籍·数学之美·绝对边界
Malone-AI12 天前
f(n)=af(n-1)+b根据一阶线性递推式推导通项公式
数学·数列
闻缺陷则喜何志丹12 天前
【解析几何丘维声 第二章】空间的平面和直线
数学·向量·解析几何·点乘·叉乘
Sunsets_Red14 天前
ABC462D 题解
c++·数学·编程·比赛·atcoder·信息学竞赛·信息学