版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 注册会计师战略中ESG战略实施的管理体系
- 2026年企业借款合同法律效力认定标准
- 2026重庆市璧山区人民医院上半年编外人才招聘41人备考题库及参考答案详解(考试直接用)
- 2026广东广州市白云区人民政府松洲街道办事处第一次招聘项目人员9人备考题库含答案详解(b卷)
- 2026河南黄金叶投资管理有限公司所属企业大学生招聘18人备考题库(含答案详解)
- 2026广西崇左天等县市场监督管理局招聘编外工作人员1人备考题库带答案详解(满分必刷)
- 2026山东青岛海关缉私局警务辅助人员招聘10人备考题库及参考答案详解(综合题)
- 2026中盐东兴盐化股份有限公司招聘17人备考题库带答案详解(培优)
- 2026春季浙商银行校园招聘备考题库附参考答案详解(综合卷)
- 2026四川内江市隆昌市普润镇人民政府招聘1人备考题库附答案详解(基础题)
- 工程质量验收规范练习题及答案
- 2026年体育场馆物业赛事活动保障方案
- 2025年北京市各区高三语文一模作文范文汇编(议论文部分)
- 发电公司现货交易奖惩制度
- 第十章 言语与语言障碍儿童
- 钢结构防腐防火涂装施工方案
- 《基于故障树的飞机液压系统典型故障的排故方案优化分析》13000字(论文)
- 安徽省2024年中考化学真题(含答案)
- 第十五届全国交通运输行业“极智杯”公路收费及监控员职业技能大赛考试题库-上(单选题部分)
- 基础护理学-第十一章-排泄试题及答案
- 船舶与海上技术 液化天然气燃料船舶加注规范
评论
0/150
提交评论