C语言打印杨辉三角形的示例代码_第1页
C语言打印杨辉三角形的示例代码_第2页
C语言打印杨辉三角形的示例代码_第3页
C语言打印杨辉三角形的示例代码_第4页
C语言打印杨辉三角形的示例代码_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第C语言打印杨辉三角形的示例代码目录1.题目描述2.解题思路3.动图演示4.代码实现Step1Step2居中显示5.完整代码6.特性总结

1.题目描述

杨辉三角形

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

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

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

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

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

2.解题思路

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

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

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

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

3.动图演示

4.代码实现

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

1、两边都是数字1;

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

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

Step1

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

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

3、输出数组所有元素

#includestdio.h

intmain()

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

intdata[9][9];

inti=0;

intj=0;

for(i=0;ii++)

for(j=0;jj++)

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

data[i][j]=1;

//输出数组所有元素

for(i=0;ii++)

for(j=0;jj++)

printf("%6d",data[i][j]);

printf("\n");

return0;

我们输出看一下

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

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

#includestdio.h

intmain()

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

intdata[9][9];

inti=0;

intj=0;

for(i=0;ii++)

for(j=0;jj++)

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

data[i][j]=1;

//输出数组所有元素

for(i=0;ii++)

//修改j=i

for(j=0;jj++)

printf("%6d",data[i][j]);

printf("\n");

return0;

运行看一看

Step2

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

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

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

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

#includestdio.h

intmain()

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

intdata[9][9];

inti=0;

intj=0;

for(i=0;ii++)

for(j=0;jj++)

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

data[i][j]=1;

//dp

for(i=1;ii++)

for(j=1;jj++)

data[i][j]=data[i-1][j]+data[i-1][j-1];

//输出数组所有元素

for(i=0;ii++)

for(j=0;jj++)

printf("%6d",data[i][j]);

printf("\n");

return0;

运行结果

居中显示

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

就像这样

很简单,代码如下

for(intk=0;k26-(6*i/2);k++)

printf(""

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论