组合取球-2022年全国青少年信息素养大赛Python国赛第6题_2023年青少年信息素养大赛python-程序员宅基地

技术标签: 少儿编程竞赛  python  全国青少年信息素养大赛Python  全国青少年信息素养大赛  开发语言  

 [导读]:超平老师计划推出《全国青少年信息素养大赛Python编程真题解析》50讲,这是超平老师解读Python编程挑战赛真题系列的第8讲。

全国青少年信息素养大赛(原全国青少年电子信息智能创新大赛)是“世界机器人大会青少年机器人设计与信息素养大赛”赛事之一,由中国电子学会主办,包含很多赛项,大赛自2013年举办,已连续成功举办八届,已正式入围“2022-2025学年面向中小学生的全国性竞赛活动名单”。 

大赛旨在激发广大青少年的科学兴趣和想象力,培养钻研探究、创新创造的科学精神和实践能力,促进青少年科技创新活动的广泛开展,发现和培养一批具有科研潜质和创新精神的青少年科技创新后备人才。

大赛主要竞赛类别包括电子科技、智能机器人、软件编程三类,全国青少年Python编程挑战赛就属于其中的软件编程类。

一.赛事说明

2021-2022年(第8届)Python挑战赛赛程分为初赛、复赛和总决赛三个阶段。初赛是资格赛,复赛是地方选拔赛,总决赛是全国各地选拔的精英汇聚在一起进行PK。

2021-2022年全国青少年Python编程挑战全国总决赛于2022年8月27日正式举行。一共是10道编程题,每道题100分,满分1000分,考试时间是120分钟。

10道编程题分别如下:

超平老师将分10讲对每道题进行详细的解读和剖析,今天要解读的是第6题,组合取球。

二.题目描述

题目背景:

一个箱子里面存放着50个球,其中10个红色,10个黄色,30个蓝色。

现在从箱子里面任意取n个球,计算并输出不同颜色的球的数量组合一共有多少种可能性。

输入描述:

一个数字n

输出描述:

一个数字,可能的组合总数

样例输入:

2

样例输出:

6

注意:

input()内不添加任何参数

只有完全正确才可提交,若无法点击提交说明答题存在错误,可及时进行检查并修改

三.思路分析

粗略一看,这是一个组合问题,但是这不是一个在m个小球中选n个小球的简单组合,而是从3种不同颜色的小球堆中选出n个小球的复杂组合。

针对此类组合问题,通常有两种解决思路,一是使用枚举算法,二是使用组合的方法。组合方法难度相对要大一些,枚举则是更简单的实现方式,这里重点介绍枚举算法的思路。

我们假定红色球选x个,黄色球选y个,蓝色球选z个,根据题目的描述,x、y、z满足如下条件:

x + y + z = n
0 ≤ x ≤ 10  
0 ≤ y ≤ 10   
0 ≤ z ≤ 30

x + y + z  = n 就是数学中的三元一次方程式,它有多组解,比如,当n = 2时,可以有如下不同组合:


x = 2 y = 0 z = 0
x = 0 y = 2 z = 0
x = 0 y = 0 z = 2
x = 1 y = 1 z = 0
x = 1 y = 0 z = 1
x = 0 y = 1 z = 1

可以将他们以元组的形式保存到列表中,如下:

[ (2,0,0),(0,2,0),(0,0,2),(1,1,0),(1,0,1),(0,1,1)]

针对3个变量,我们使用枚举算法,也就是3层循环就可以实现。

接下来,我们进入具体的编程实现环节。

 

四.编程实现

根据上面的思路分析,我们编写代码如下:


# 获取数字n
n = int(input())
# 枚举算法
result = []
for x in range(10):
  for y in range(10):
    for z in range(30):
      if x + y + z == n and (x,y,z) not in result:
        result.append((x,y,z))
# 输出组合总数
print(len(result))

简单说明两点:

1). 为了避免重复组合,第9行代码做了去重处理;

2). 每一种组合,可以使用元组(x, y , z)来表示,也可以使用列表[x, y, z]来表示; 

运行程序,如果输入数字2,可以得到如下组合:

[(0,0,2),(0,1,1),(0,2,0),(1,0,1),(1,1,0),(2,0,0)]

如果输入数字3,可以得到如下组合:

[(0,0,3),(0,1,2),(0,2,1),(0,3,0),(1,0,2), 
  (1,1,1),(1,2,0),(2,0,1),(2,1,0),(3,0,0)]

五.总结与思考

本题难度中等,考查的知识点主要包括:

  • 输入输出函数;

  • 循环嵌套语句;

  • 列表操作;

  • 枚举算法;

善于思考的同学可能已经发现了,题目描述中有一条信息可能会产生干扰作用,这就是“箱子里面存放着50个球”。有些同学在分析思考的时候,会纠结如何在50个小球中取n个小球的问题上。

实际上,50个小球分成了3堆,分别是10个红色球、10个黄色球和30个蓝色球,然后分别从三堆小球中取球,如此一来,就自然而然想到枚举算法了。

如果你熟练掌握了列表推导式的用法,上面的代码,还可以进一步进化,如下:

n = int(input())
result = [(x,y,z) for x in range(10) for y in range(10) for z in range(30)  if x + y + z == n]
print(len(result))

除此之外,还可以itertools库中的product函数来解决,你知道是怎么实现的,赶紧动手试一下吧。

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

更多教程请移步至“超平的编程课”gzh。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/diamondwang2012/article/details/131668581

智能推荐

oracle 12c 集群安装后的检查_12c查看crs状态-程序员宅基地

文章浏览阅读1.6k次。安装配置gi、安装数据库软件、dbca建库见下:http://blog.csdn.net/kadwf123/article/details/784299611、检查集群节点及状态:[root@rac2 ~]# olsnodes -srac1 Activerac2 Activerac3 Activerac4 Active[root@rac2 ~]_12c查看crs状态

解决jupyter notebook无法找到虚拟环境的问题_jupyter没有pytorch环境-程序员宅基地

文章浏览阅读1.3w次,点赞45次,收藏99次。我个人用的是anaconda3的一个python集成环境,自带jupyter notebook,但在我打开jupyter notebook界面后,却找不到对应的虚拟环境,原来是jupyter notebook只是通用于下载anaconda时自带的环境,其他环境要想使用必须手动下载一些库:1.首先进入到自己创建的虚拟环境(pytorch是虚拟环境的名字)activate pytorch2.在该环境下下载这个库conda install ipykernelconda install nb__jupyter没有pytorch环境

国内安装scoop的保姆教程_scoop-cn-程序员宅基地

文章浏览阅读5.2k次,点赞19次,收藏28次。选择scoop纯属意外,也是无奈,因为电脑用户被锁了管理员权限,所有exe安装程序都无法安装,只可以用绿色软件,最后被我发现scoop,省去了到处下载XXX绿色版的烦恼,当然scoop里需要管理员权限的软件也跟我无缘了(譬如everything)。推荐添加dorado这个bucket镜像,里面很多中文软件,但是部分国外的软件下载地址在github,可能无法下载。以上两个是官方bucket的国内镜像,所有软件建议优先从这里下载。上面可以看到很多bucket以及软件数。如果官网登陆不了可以试一下以下方式。_scoop-cn

Element ui colorpicker在Vue中的使用_vue el-color-picker-程序员宅基地

文章浏览阅读4.5k次,点赞2次,收藏3次。首先要有一个color-picker组件 <el-color-picker v-model="headcolor"></el-color-picker>在data里面data() { return {headcolor: ’ #278add ’ //这里可以选择一个默认的颜色} }然后在你想要改变颜色的地方用v-bind绑定就好了,例如:这里的:sty..._vue el-color-picker

迅为iTOP-4412精英版之烧写内核移植后的镜像_exynos 4412 刷机-程序员宅基地

文章浏览阅读640次。基于芯片日益增长的问题,所以内核开发者们引入了新的方法,就是在内核中只保留函数,而数据则不包含,由用户(应用程序员)自己把数据按照规定的格式编写,并放在约定的地方,为了不占用过多的内存,还要求数据以根精简的方式编写。boot启动时,传参给内核,告诉内核设备树文件和kernel的位置,内核启动时根据地址去找到设备树文件,再利用专用的编译器去反编译dtb文件,将dtb还原成数据结构,以供驱动的函数去调用。firmware是三星的一个固件的设备信息,因为找不到固件,所以内核启动不成功。_exynos 4412 刷机

Linux系统配置jdk_linux配置jdk-程序员宅基地

文章浏览阅读2w次,点赞24次,收藏42次。Linux系统配置jdkLinux学习教程,Linux入门教程(超详细)_linux配置jdk

随便推点

matlab(4):特殊符号的输入_matlab微米怎么输入-程序员宅基地

文章浏览阅读3.3k次,点赞5次,收藏19次。xlabel('\delta');ylabel('AUC');具体符号的对照表参照下图:_matlab微米怎么输入

C语言程序设计-文件(打开与关闭、顺序、二进制读写)-程序员宅基地

文章浏览阅读119次。顺序读写指的是按照文件中数据的顺序进行读取或写入。对于文本文件,可以使用fgets、fputs、fscanf、fprintf等函数进行顺序读写。在C语言中,对文件的操作通常涉及文件的打开、读写以及关闭。文件的打开使用fopen函数,而关闭则使用fclose函数。在C语言中,可以使用fread和fwrite函数进行二进制读写。‍ Biaoge 于2024-03-09 23:51发布 阅读量:7 ️文章类型:【 C语言程序设计 】在C语言中,用于打开文件的函数是____,用于关闭文件的函数是____。

Touchdesigner自学笔记之三_touchdesigner怎么让一个模型跟着鼠标移动-程序员宅基地

文章浏览阅读3.4k次,点赞2次,收藏13次。跟随鼠标移动的粒子以grid(SOP)为partical(SOP)的资源模板,调整后连接【Geo组合+point spirit(MAT)】,在连接【feedback组合】适当调整。影响粒子动态的节点【metaball(SOP)+force(SOP)】添加mouse in(CHOP)鼠标位置到metaball的坐标,实现鼠标影响。..._touchdesigner怎么让一个模型跟着鼠标移动

【附源码】基于java的校园停车场管理系统的设计与实现61m0e9计算机毕设SSM_基于java技术的停车场管理系统实现与设计-程序员宅基地

文章浏览阅读178次。项目运行环境配置:Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。项目技术:Springboot + mybatis + Maven +mysql5.7或8.0+html+css+js等等组成,B/S模式 + Maven管理等等。环境需要1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。_基于java技术的停车场管理系统实现与设计

Android系统播放器MediaPlayer源码分析_android多媒体播放源码分析 时序图-程序员宅基地

文章浏览阅读3.5k次。前言对于MediaPlayer播放器的源码分析内容相对来说比较多,会从Java-&amp;amp;gt;Jni-&amp;amp;gt;C/C++慢慢分析,后面会慢慢更新。另外,博客只作为自己学习记录的一种方式,对于其他的不过多的评论。MediaPlayerDemopublic class MainActivity extends AppCompatActivity implements SurfaceHolder.Cal..._android多媒体播放源码分析 时序图

java 数据结构与算法 ——快速排序法-程序员宅基地

文章浏览阅读2.4k次,点赞41次,收藏13次。java 数据结构与算法 ——快速排序法_快速排序法