杨辉三角形-第11届蓝桥杯选拔赛Python真题精选

news2024/9/29 19:26:56

[导读]:超平老师的Scratch蓝桥杯真题解读系列在推出之后,受到了广大老师和家长的好评,非常感谢各位的认可和厚爱。作为回馈,超平老师计划推出《Python蓝桥杯真题解析100讲》,这是解读系列的第17讲。

杨辉三角形,本题是2019年12月15日举办的第11届蓝桥杯青少组Python编程选拔赛真题,题目要求编写程序输出指定行数的杨辉三角形。

先来看看题目的要求吧。

一.题目说明

提示信息:

杨辉三角形,是二项式系数在三角形中的一种几何排列。中国南宋数学家杨辉在1261年所著的 《详解九章算法》一书有明确记载。欧洲数学家帕斯卡在1654年发现这一规律,所以又叫做帕斯卡三角形。

其定义为:其顶端(第1行)是1;第2行是两个1;第3行是'1 2 1',中间的'2'是其上方相邻的两个数字的和;依此类推,产生如图所示的杨辉三角形。

图片

编程实现:

对于任意输入的3~15之间的正整数n,请编程输出前n行数字、以及由其组成的杨辉三角形。 

函数提示:

print('{:< 3}'.format(10))能够以3个字符宽度、左对齐的方式显示数字10。

输入描述:

一个正整数n(2 ≤ n ≤ 15)

输出描述:

由两部分组成。第一部分输出由n行数字组成的列表;第二部分输出n行数字组成的杨辉三角形,具体输出格式参考如下样例。

样例输入:

6

样例输出:

图片

评判标准:

下列各评分项单独计分,得分累加,共35个计分点。

  • 15分:正确输出n行数字组成的列表;

  • 9分:正确输出n行数字组成的杨辉三角形,输出格式不需要完全符合样例;

  • 11分:正确输出n行数字组成的杨辉三角形,且格式符合样例,即要求各数字间距相同、左右对称、上下隔行对齐。

二.思路分析

这是一道算法题,考查的知识点主要包括循环、列表操作、输出控制和算法等。

你知道吗,中国古代数学史曾经有自己光辉灿烂的篇章,在数学的许多重要领域中处于遥遥领先的地位,杨辉三角形的发现就是十分精彩的一页。

图片

要解决本题,首先需要找到这其中的规律,相信聪明的你已经发现了,杨辉三角形具有如下4个特性:

1). 第n行的数字有n个

2). 每行首位数字和末位数字都是1;

3). 每行中间的各项数字都是它肩上两个数字的和;

4). 第n行的项数总比第n-1行多1。

尤其是第3点,这是关键,我们可以结合动图来理解:

图片

但是,我们的数据是保存在列表中的,将上图转换成规则的表格形式,如下:

图片

这样看起来就比较清楚了,除了第1行和第2行之外,从第3行开始,每一行的中间项(除首尾两项)都满足如下公式:

a[i][j] = a[i-1][j-1] + a[i-1][j]

这里的i表示行,j表示列,其中,a[i-1][j-1]是左上方的列表项,a[i-1][j]是正上方的列表项。

这其实就是递推算法,那什么是递推算法呢?

递推算法是一种简单的算法,其核心思想是根据已有的数据和关系,逐步推导而得到结果。

递推算法的特点是,一个问题的求解需要一系列的计算,在已知条件和所求问题之间总存在着某种相互联系的关系,在计算时,需要找到前后项之间的关系,即推导公式。

根据上面的分析,我们可以将本题分成如下几步来实现:

  • 初始化列表,包括前两行;

  • 使用递推算法构造整个列表

  • 输出列表

  • 输出杨辉三角形

思路有了,接下来,我们就进入具体的编程实现环节。

三.编程实现

根据上面的思路分析,我们分4步来编写程序:

  • 初始化列表;

  • 使用递推算法构造整个列表

  • 输出列表

  • 输出杨辉三角形

1. 初始化列表

这一步,非常简单,只需要完成两个任务,一是获取用户输入的行数,二是创建一个二维列表,编写代码如下:

图片

由于这里只需要初始化列表的前两项,所以在构造的时候直接写上即可,和行数n没有关系。

2. 使用递推算法构造整个列表

根据前面的思路分析,从第3行开始,使用递推算法逐步构造列表项,继续编写代码如下:

图片

这部分代码是本题的关键,也是难点,重点说明一下。

由于列表的第1行和第2行已经有了,所以在循环的时候,i从2开始,表示第3行,到n-1行结束,包括第n-1行。

对于第i行,首先构造一个一维列表,并将所有的初始值设为1。

比如i = 2时,表示第3行,有3项数据,构造的列表为:

[1, 1, 1]

再如i = 3时,表示第4行,有4项数据,构造的列表为:

[1, 1, 1, 1]

又如i = 4时,表示第5行,有5项数据,构造的列表为:

[1, 1, 1, 1, 1]

将构造好的列表追加到tri列表中,然后使用循环,对中间项进行推导,所以变量j的范围是(1,i),第一项和最后一项则保持1不变。

3. 输出列表

列表构造完毕,直接使用for循环输出即可,代码如下:

图片

4. 输出杨辉三角形

按照题目要求,需要输出三角形的形状,并且各数字间距相同、左右对称、上下隔行对齐,这个该怎么实现呢?

关于对齐效果,Python提供了center()函数,用法如下:

str.center(width[, fillchar])

其中,width表示字符串的总宽度,fillchar则表示填充字符,默认为空格。

有了这个函数,问题就变得简单了,只需要将数字转成字符串,然后调用center()方法即可,那么,这里的width设置多少比较合适呢?

题目中明确给出了n的取值范围为[2,15],当n=15时,最大的数字为3432,所以宽度必须要大于4,同时确保左右各空一格,所以设置为6比较合适。

然后就是每一行需要输出空格,空格的数量和行数有关系,以n=6为例,

图片

根据上面的表格,我们可以总结出如下规律:​​​​​​

第1行,左边要空出5个单元格,即6 - 0 - 1第2行,左边要空出4个单元格,即6 - 1 - 1第3行,左边要空出3个单元格,即6 - 2 - 1......第i行,左边要空出n - i - 1个单元格

注意,这里的i是从0开始的。

所以,对于第i行而言,要输出的空格数为:

 (n - i - 1) * 3

之所以乘以3,是因为每个数字的宽度为6,6/2 = 3。

分析完毕,就可以编写代码了,如下:

图片

运行程序,输入数字6,效果如下:

图片

再输入数字15,效果如下:

图片

怎么样,对齐效果还是非常nice的吧,至此,整个程序就全部完成了,你也可以输入不同的数字来测试效果。

四.总结与思考

本题的分数为35分,代码在15行左右,涉及到的知识点包括:

  • 循环语句,主要for...in循环;

  • 列表运算,尤其是二维列表;

  • 输出格式控制;

  • 递推算法;

题目难度较大,尤其是对于初学者。难点有两个,一是如何找到杨辉三角数据之间的规律,这是实现递推算法的关键所在,二是如何使用二维列表来表示杨辉三角,并构造出列表。

考生除了要具备扎实的Python语法基础之外,同时还需要具备一定的算法思维,随着学习的不断深入,算法会变得越来越重要。

递推法是一种重要的数学方法,在数学的各个领域中都有广泛的运用,也是计算机用于数值计算的一个重要算法。这种处理问题的方法能将复杂运算简化为若干步重复的简单运算,充分发挥出计算机擅长于重复处理的特点。

使用递推算法,把一个复杂的问题的求解,分解成了连续的若干步简单运算,从这个角度来讲,可以将递推算法看成是一种特殊的迭代算法。

超平老师给你留一道思考题,除了上面讲到的方法外,还有没有其它的方法,具体又是如何实现的呢?

你还有什么好的想法和创意吗,也非常欢迎和超平老师分享探讨。

如果你觉得文章对你有帮助,别忘了点赞和转发,予人玫瑰,手有余香😄

需要源码的,可以移步至“超平的编程课”gzh。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1309360.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

低代码 —— 饮食均衡,合理膳食

目录 一、低代码的概念 二、低代码的优缺点 &#xff08;一&#xff09;优点 &#xff08;二&#xff09;缺点 三、低代码的能力 1、场景构建能力 2、数据编排能力 3、连接生态能力 4、业务中台能力 四、你认为低代码会替代传统编程吗&#xff1f; 1、从技术特征来看…

前端已死?探讨人工智能与低代码对前端的影响

文章目录 每日一句正能量前言前端行业究竟是好是坏&#xff1f;数字化转型的当下前端工程师该何去何从&#xff1f; 想要入行前端先认清这三个事实 后记 每日一句正能量 人的结构就是相互支撑&#xff0c;众人的事业需要每个人的参与。 前言 随着人工智能和低代码的崛起&#…

软件设计师——信息安全(一)

&#x1f4d1;前言 本文主要是【信息安全】——软件设计师——信息安全的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他 &#x1f304…

ISCTF2023 Reverse方向 WP

文章目录 ReversecrackmeEasyRebabyReeasy_z3FloweyRSAeasy_flower_teamfx_rez3_revengeWHERE Reverse crackme 、 加了UPX壳&#xff0c;可以看到EP Section处UPX标识被修改了 用WinHex修改 之后UPX脱壳 得到flag。 EasyRe 逆向一下&#xff0c;先逆序&#xff0c;再做一些…

华为云sp2服务器系统根分区扩容后重启失败解决

lvm根分区扩容 概念&#xff1a; PV&#xff08;物理卷&#xff1a;Physical Volumes&#xff09; VG&#xff08;物理卷组&#xff1a;Volume Group&#xff09; LV&#xff08;逻辑卷&#xff1a;Logical Volumes&#xff09; R系 V10服务器&#xff1a; 显示当前Logic…

HTTP、HTTPS、SSL协议以及相关报文讲解

目录 HTTP/HTTPS介绍 HTTP/HTTPS基本信息 HTTP如何实现有状态 HTTP请求与应答报文 HTTP请求报文 HTTP响应报文 SSL协议 SSL单向认证 SSL双向认证 HTTP连接建立与传输步骤 HTTP访问全过程相关报文&#xff08;以访问www.download.cucdccom为例子&#xff09; DNS报文…

努比亚×实在RPA丨全域数据获取时长降低67%以上,累计节省人天1900+

国际知名数码品牌努比亚的服务和销售网络遍及海内外市场&#xff0c;其中&#xff0c;国内线上渠道包含淘系、京东、拼多多、快手等10余个主流电商平台。 为了更好满足年轻消费群体需求&#xff0c;努比亚每天需要获取各平台销售数据&#xff0c;对于需要管理10平台的运营部门…

@Valid注解的使用

Valid注解的使用 Valid 用来对参数进行验证&#xff0c;在变量信息中添加用于充当校验条件的注解 需要传入BindingResult对象&#xff0c;用于获取校验失败情况下的反馈信息 用法示例

DevOps搭建(十)-安装Harbor镜像仓库详细步骤

1、下载Harbor 官方地址: https://goharbor.io/ 下载地址: https://github.com/goharbor/harbor/tags 选择文档版本进行下载,这里我们选择v2.7.2版本 2、上传到服务器并解压 上传压缩包到服务器后,解压到/usr/local目录下,执行以下解压命令 tar -zxvf harbor-offli…

windows任务计划的创建、导出和导入

创建任务计划 任务名称 任务触发器 执行bat的话起始于必须填写 创建成功 导出任务计划 选择导出路径 导出成功 导入任务计划 可视化界面导入任务计划 选择任务计划的xml文件 点击确定 导入成功 命令行导入计划任务 cd /d D:\迅雷下载schtasks.exe /create /tn 1234 /xml 123…

【XR806开发板试用】+2.鸿蒙内核

非常感谢基于安谋科技STAR-MC1的全志XR806 Wi-FiBLE开源鸿蒙开发板试用活动&#xff01;非常感谢极术社区&#xff01;非常感谢极术小姐姐&#xff01;非常感谢全志在线开发者社区&#xff01;非常感谢通过试用申请&#xff01;非常感谢安谋科技&#xff01; 接上一篇&#xff…

CSS新手入门笔记整理:CSS定位布局

定位布局概述 浮动布局比较灵活&#xff0c;但是不容易控制。而定位布局的出现&#xff0c;使得用户精准定位页面中的任意元素成为可能。当然了&#xff0c;由于定位布局缺乏灵活性&#xff0c;这给空间大小和位置不确定的版面布局带来困惑。因此在实际开发中&#xff0c;大家…

数据服务化在京东的实践

01 缘起&#xff1a;数据服务化从 0 到 1 1. 缘起 京东数据智能部负责维护数据资产和对外提供数据服务&#xff0c;很多业务方要求我们尽快地提供开放的数据 API供其使用&#xff0c;但开发一个 API 的平均周期在两周左右&#xff0c;遇到 618 大促时还要提供 80 个接口。在…

Mrdoc知识文档

MrDoc知识文档平台是一款基于Python开发的在线文档系统&#xff0c;适合作为个人和中小型团队的私有云文档、云笔记和知识管理工具&#xff0c;致力于成为优秀的私有化在线文档部署方案。我现在主要把markdown笔记放在上面&#xff0c;因为平时老是需要查询一些知识点&#xff…

一张图看懂NvMDynamicConfiguration和NvMResistantToChangedSw对NvM数据变更的影响

一、背景 在实际项目中&#xff0c;我们会通过NvM将易失性数据存入EEPRAM。如果说NvM中配置好的Block List在项目迭代过程中没有Block的增加或减少&#xff0c;没有Block数据长度的增加或减少&#xff0c;那么NvM的使用就不会有什么问题。 但是如果Block List在某一天要增加一…

C_10练习题答案

一、单项选择题(本大题共 20小题,每小题 2分,共 40分。在每小题给出的四个备选项中,选出一个正确的答案,并将所选项前的字母填写在答题纸的相应位置上。) 1,结构化程序由三种基本结构组成,三种基本结构组成的算法是(A) A.可以完成任何复杂的任务 B.只能完成部分复杂的任务…

护眼台灯真的护眼吗?专业的学生护眼台灯推荐

最为家长&#xff0c;日常最关心的事情除了孩子的学习以外&#xff0c;就是视力健康问题。通过数据显示&#xff0c;在我国小学生人群中&#xff0c;每47人中就有一位近视&#xff0c;发病率约为23%。中学生约为55%,大学生约为76%,这个近视率是非常高的&#xff0c;因此很多家长…

C语言 内存操作函数 +内存分区

内存操作函数 memset() //memset 函数将指定内存区域 ptr 开始的 num 个字节设置为 value。 void *memset(void *ptr, int value, size_t num);参数&#xff1a;ptr&#xff1a;指向要填充的内存区域的指针。value&#xff1a;要填充的值&#xff0c;以整数形式传递。num&…

专题地图制作与布局编辑

一、实验名称&#xff1a; 专题地图制作与布局编辑 二、实验目的&#xff1a; 通过本实验练习&#xff0c;掌握ARCGIS专题地图制作与布局编辑。 三、实验内容和要求&#xff1a; 实验内容&#xff1a; 利用ARCGIS软件相关分析工具及实验数据&#xff0c;制作专题地图&…

MySQL索引_什么是索引_索引的分类_什么时候需要/不需要创建索引_优化索引_索引失效

文章目录 索引1. 什么是索引2. 索引的分类按数据结构分类按物理存储分类按字段特性分类按字段个数分类 3. 什么时候需要 / 不需要创建索引&#xff1f;什么时候适用索引&#xff1f;什么时候不需要创建索引&#xff1f; 4. 优化索引的方法前缀索引优化覆盖索引优化主键索引最好…