美文网首页C语言
杨辉三角形

杨辉三角形

作者: sure_风雨与晴 | 来源:发表于2019-03-01 21:17 被阅读1次
    1. 每个数等于它上方两数之和。
    2. 每行数字左右对称,由1开始逐渐变大。
    3. 第n行的数字有n项。
    4. 第n行的m个数可表示为从n-1个不同元素中取m-1个元素的组合数。
    5. 第n行的第m个数和第n-m+1个数相等 ,为组合数性质之一。
    6. 每个数字等于上一行的左右两个数字之和。可用此性质写出整个杨辉三角。即第n+1行的第i个数等于第n行的第i-1个数和第i个数之和,这也是组合数的性质之一。即 C(n+1,i)=C(n,i)+C(n,i-1)
    #include <stdio.h>
    #include <stdlib.h>
    #define N 20
    
    void CaculateYH(int a[][N], int n);
    void PrintYH(int a[][N], int n);
    int main()
    {
        int a[N][N] = {0}, n;
        printf("Input n (n<20):");
        scanf("%d", &n);
        CaculateYH(a,n);
        PrintYH(a, n);
        return 0;
    }
    
    //计算杨辉三角型前n行元素的值
    void CaculateYH(int a[][N], int n)
    {
        int i, j;
        for (i = 0; i < n; i++)
        {
            a[i][0] = 1;
            a[i][i] = 1;    //每行第一个和最后一个数是18
        }
        for (i = 2; i < n; i++)
        {
            for (j = 1; j <= i-1; j++)
                a[i][j] = a[i-1][j-1] + a[i-1][j];       //此值=上一行此列值+上一行前一列值
        }
    }
    
    //输出杨辉三角形前n行元素的值
    void PrintYH(int a[][N], int n)
    {
        int i, j, k;
        for (i = 0; i < n; i++)
        {
            for (k = i; k < n; k++)
                printf("  ");
            for (j = 0; j <= i; j++)
                printf("%4d", a[i][j]);
            printf("\n");
        }
    }
    

    相关文章

      网友评论

        本文标题:杨辉三角形

        本文链接:https://www.haomeiwen.com/subject/pwwjuqtx.html