文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言如何打印杨辉三角形

2023-06-29 02:53

关注

小编给大家分享一下C语言如何打印杨辉三角形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

1. 题目描述

杨辉三角形

解题之前,我们先来了解一下杨辉三角形到底是什么?

杨辉三角形,又称帕斯卡三角形、贾宪三角形、海亚姆三角形,它的排列形如三角形。

因为首现于南宋杨辉的《详解九章算法》得名,而书中杨辉说明是引自贾宪的《释锁算书》,故又名贾宪三角形。

古代波斯数学家欧玛尔·海亚姆也描述过这个三角形。在欧洲,因为法国数学家布莱兹‧帕斯卡在1653年的《论算术三角》中首次完整论述了这个三角形,故也被称作帕斯卡三角(Pascal’s triangle)。

杨辉三角的前10行写出来如下

C语言如何打印杨辉三角形

2. 解题思路

其实规律很简单,我们来看一看

在最上面一行的中央写下数字 1;

第二行,写下两个1,和上一行形成三角形;

随后的每一行,开头和最后的数字都是1,其他的每个数都是它左上方和右上方的数之和,就是说除每行最左侧与最右侧的数字以外,每个数字等于它的左上方与右上方两个数字之和。

C语言如何打印杨辉三角形

3. 动图演示

C语言如何打印杨辉三角形

4. 代码实现

我们通过动图可以得出以下结论

两边都是数字1;

从第三行开始,除了两边的数字1之外的数字都是由 “肩膀上” 的数字相加得到的。

对于算法不太熟悉的朋友,如果直接去打印,可能就比较困难,所以我们不妨拆开几步来做。

Step1

定义一个9行9列的二维整型数组;

数组所有元素都赋值为1;

输出数组所有元素

#include <stdio.h>int main(){    //定义一个9行9列的二维整型数组    int data[9][9];    int i = 0;    int j = 0;    for (i = 0; i < 9; i++)    {        for (j = 0; j < 9; j++)        {            //数组所有元素都赋值为1            data[i][j] = 1;        }    }    //输出数组所有元素    for (i = 0; i < 9; i++)    {         for (j = 0; j < 9; j++)         {             printf("%6d", data[i][j]);         }         printf("\n");    }    return 0;}

我们输出看一下

C语言如何打印杨辉三角形

但是我们只需要左下角的数字

C语言如何打印杨辉三角形

所以对第二个for循环进行修改,让j <= i;

#include <stdio.h>int main(){    //定义一个9行9列的二维整型数组    int data[9][9];    int i = 0;    int j = 0;    for (i = 0; i < 9; i++)    {        for (j = 0; j < 9; j++)        {            //数组所有元素都赋值为1            data[i][j] = 1;        }    }    //输出数组所有元素    for (i = 0; i < 9; i++)    {    //修改j <= i         for (j = 0; j <= i; j++)         {             printf("%6d", data[i][j]);         }         printf("\n");    }    return 0;}

运行看一看

C语言如何打印杨辉三角形

Step2

中间位置的数字是由它上一行对应位置的数字以及上一行对应位置左侧的数字相加得到;

因为下一行的情况总需要由上一行的情况推出,即我们需要记录每一行的结果。

所以构建杨辉三角本质上是一个动态规划问题,我们可以总结出如下推导式:

C语言如何打印杨辉三角形

其中,dp[i][j]表示第i行的第j个数。

#include <stdio.h>int main(){    //定义一个9行9列的二维整型数组    int data[9][9];    int i = 0;    int j = 0;    for (i = 0; i < 9; i++)    {        for (j = 0; j < 9; j++)        {            //数组所有元素都赋值为1            data[i][j] = 1;        }    }    //dp    for (i = 1; i < 9; i++)    {        for (j = 1; j < i; j++)        {            data[i][j] = data[i-1][j] + data[i-1][j-1];        }    }    //输出数组所有元素    for (i = 0; i < 9; i++)    {         for (j = 0; j <= i; j++)         {             printf("%6d", data[i][j]);         }         printf("\n");    }    return 0;}

运行结果

C语言如何打印杨辉三角形

居中显示

我们如何让杨辉三角形居中显示呢?

就像这样

C语言如何打印杨辉三角形

很简单,代码如下

        for (int k = 0; k < 26 - (6 * i / 2); k++)        {            printf(" ");        }

这是什么意思呢?

每行前输出不等的空格;

为何i / 2?因为:居中只需左边加空格;

为何要乘6?因为:输出时用%6d;

为何要用26减?因为:不大不小刚刚好????

C语言如何打印杨辉三角形

5. 完整代码

代码示例

#include <stdio.h>int main(){    //定义一个9行9列的二维整型数组    int data[9][9];    int i = 0;    int j = 0;    for (i = 0; i < 9; i++)    {        for (j = 0; j < 9; j++)        {            //数组所有元素都赋值为1            data[i][j] = 1;        }    }    //dp    for (i = 1; i < 9; i++)    {        for (j = 1; j < i; j++)        {            data[i][j] = data[i - 1][j] + data[i - 1][j - 1];        }    }    //输出数组所有元素    for (i = 0; i < 9; i++)    {    //用三角形的方式打印        for (int k = 0; k < 26 - (6 * i / 2); k++)        {            printf(" ");        }        for (j = 0; j <= i; j++)        {            printf("%6d", data[i][j]);        }        printf("\n");    }    return 0;}

6. 特性总结

杨辉三角的美妙之处在于:它是如此足够简单,但本身在数学上却拥有丰富的魅力。

这是数学中的最令人称奇的事物之一,随便取诸多数学性质中的某个,就能表明它是多么的精彩绝伦。

比如:隐藏数列、完全平方数、斐波那契数列、谢尔宾斯基三角、组合数学、二项式定理等等,这些都都可以在杨辉三角形中找到,你发现了吗?

以上是“C语言如何打印杨辉三角形”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯