C语言:简单的用二维数组打印杨氏三角

杨辉三角,又称帕斯卡三角,是一个数学上的规律图形。它的构造规则如下:

  1. 每一行的两个端点数字是1。

  2. 从第三行开始,每个数字是它上方两个数字的和。

  3. 每一行数字左右对称。

    #include<stdio.h>
    int main()
    {
    int arr[50][50];//定义一个二维数组存储杨辉三角
    int i, j, n;
    scanf("%d", &n);
    //第一个for循环产生行
    for (i = 0;i < n;i++)
    {
    //嵌套for循环产生列
    for (j = 0;j <= i;j++)
    {
    //杨辉三角特性:每一行首尾元素都是1
    if (i == j || j == 0)//j==0是因为每一列的元素都是1,这里可以画图方便理解
    {
    arr[i][j] = 1;
    }
    else //计算中间元素值,根据杨辉三角的特性
    arr[i][j] = arr[i - 1][j - 1] + arr[i - 1][j];//这里画图做个示例就可以明白
    }
    }
    //接下来输出杨氏三角
    for (i = 0;i < n;i++)
    {
    for (j = 0;j <= i;j++)
    {
    printf("%-5d", arr[i][j]);// 打印每个元素,并且使用 %-5d 保证输出格式对齐
    }
    printf("\n");//每打印一行完毕就换行
    }
    return 0;
    }

下面附一个草图,同学们可以自己画画,然后就可以写出来啦

相关推荐
你怎么知道我是队长16 小时前
C语言---无名位域
c语言·开发语言
星火开发设计16 小时前
C++ queue 全面解析与实战指南
java·开发语言·数据结构·c++·学习·知识·队列
橘颂TA16 小时前
【剑斩OFFER】算法的暴力美学——力扣 394 题:字符串解码
数据结构·c++·结构与算法
练习时长一年16 小时前
LeetCode热题100(杨辉三角)
算法·leetcode·职场和发展
lzllzz2317 小时前
bellman_ford算法
算法
栈与堆17 小时前
LeetCode 19 - 删除链表的倒数第N个节点
java·开发语言·数据结构·python·算法·leetcode·链表
sunfove17 小时前
麦克斯韦方程组 (Maxwell‘s Equations) 的完整推导
线性代数·算法·矩阵
如果你想拥有什么先让自己配得上拥有17 小时前
近似数的思考学习
学习
Rui_Freely17 小时前
Vins-Fusion之 SFM准备篇(十二)
人工智能·算法·计算机视觉
-森屿安年-17 小时前
unordered_map 和 unordered_set 的实现
数据结构·c++·散列表