蓝桥杯2023年省赛真题C/C++大学B组试题A:日期统计试题B:01串的熵试题C:冶炼金属试题D:飞机降落试题E:接龙数列试题F:岛屿个数试题G:子串简写试题H:整数删除试题 I:景区导游试题J:砍树要来力试题A:日期统计本题总分:555分【问题描述】 小蓝现在有一个长度为100100100的数组,数组中的每个元素的值都在000到999的范围之内。数组中的元素从左至右如下所示: 5556668886669991116661112224449991119998882223336664447777775559995550003338887775558881115558886661118883
1.问题描述:最近暑期特训算法班的同学们表现出色,他们的老师肖恩决定给他们分发糖果。肖恩购买了n个不同种类的糖果,用小写的阿拉伯字母表示。每个糖果必须分发给一个同学,并且每个同学至少要分到一个糖果。同学们的开心程度定义为他们所分到的糖果组成的字符串s[团的字典序。肖恩希望同学们的开心程度相差尽量小,因此他要找到一种方案,使得所有糖果组成的字符串中字典序最大的字符串尽可能小。请输出能够实现字典序最小可能的max(s[1],s[2],s[3],…,s[a])。2.代码:#输入糖果个数n,人数x,并排序存放数组中:n,x=map(int,input().split())candy=input()c
过去我们一直在求单源最短路,今天让我们看一下多源最短路的求法。我们介绍一下它的核心思想:即不断在原有基础上添加新的中转点并求出此时的最优状态,是一种动态规划思想的体现。具体流程:我们先列出无中转点(也就是相邻的点)间的dis;然后枚举中转点k(有点类似区间dp),转移方程为f[i][j](从i到j)=min(f[i][j],f[i][k]+f[k][j]).正确性证明:当我们先枚举a为中转时,我们就可以求得任意两点之间经过与不经过a的最短距离。当我们先枚举b为中转时,我们就可以求得任意两点之间经过a与b的排列组合(不大准确,可以选一个,也可以都不选)(也就是ab与ba,a,b,0)同理,当我们
1.邻接表 staticclassEdge{intnext;intvalue;publicEdge(intnext,intvalue){this.next=next;this.value=value;}}staticHashMap>graph=newHashMap();publicstaticvoidaddEgde(intfrom,intto,intvalue){if(!graph.containsKey(from)){graph.put(from,newLinkedList());}if(!graph.containsKey(to)){graph.put(to,newLinkedList()
[蓝桥杯2021省AB]砝码称重题目描述你有一架天平和NNN个砝码,这NNN个砝码重量依次是W1,W2,⋯ ,WNW_{1},W_{2},\cdots,W_{N}W1,W2,⋯,WN。请你计算一共可以称出多少种不同的重量?注意砝码可以放在天平两边。输入格式输入的第一行包含一个整数NNN。第二行包含NNN个整数:W1,W2,W3,⋯ ,WNW_{1},W_{2},W_{3},\cdots,W_{N}W1,W2,W3,⋯,WN。输出格式输出一个整数代表答案。样例#1样例输入#13146样例输出#110提示【样例说明】能称出的10种重量是:1、2、3、4、5、6、7、9、10、111、
目录一、贪心算法的介绍二、贪心算法的实现步骤三、最小化战斗力差距四、谈判五、纪念品分组六、分糖果一、贪心算法的介绍贪心的基本原理:每一步都选择局部最优解,而尽量不考虑对后续的影响,最终达到全局最优解。贪心的局限性:贪心算法不能保证获得全局最优解,但在某些问题上具有高效性。贪心的特征:贪心选择性质、最优子结构性质(根据我的观察,很多贪心的题目会出现“不同的操作产生的贡献相同”的特征,在此特征下我们每次选择代价最小的)。贪心的类型多且杂,难以划分,需要不断练习和积累。二、贪心算法的实现步骤1.确定问题的最优子结构(贪心往往和排序、优先队列等一起出现)2.构建贪心选择的策略,可能通过“分类讨论”、“
文章目录前言1.CubeMx配置1.1时钟源的选择1.2时钟树的配置1.3配置引脚1.4文件配置1.5工程配置2.代码编写2.1代码编写步骤2.2LED测试代码编写3.代码编写方法二前言下面对STM32G431进行模块化学习,本文先学习CubeMX的配置以及点灯操作。1.CubeMx配置1.1时钟源的选择1.2时钟树的配置HCLK一般取80(使用ADC的情况下)1.3配置引脚在产品手册中可以找到STM32G431的LED原理图,从下图可以看出,8颗LED灯通过74HC573驱动,LED灯采用低电平的方式点亮,控制引脚连PD2引脚。我们可以在PD2高电平的基础上,控制GPIOPC8~PC15的高
1、B站视频链接:E28【模板】区间DP石子合并_哔哩哔哩_bilibili题目链接:石子合并(弱化版)-洛谷#includeusingnamespacestd;constintN=310;intn,a[N],s[N];intf[N][N];//f[i][j]表示从i到j合并成一堆的最小代价intmain(){ memset(f,0x3f,sizeof(f)); cin>>n; //预处理 for(inti=1;i>a[i],s[i]=s[i-1]+a[i],f[i][i]=0; } //状态计算 for(intlen=2;len2、B站视频链接:E29区间DP环形石子合并_哔哩哔哩_bili
思路:使用模板字符串,借助time的值选择添加或移除样式的盒子,由于盒子的类名最多为li9,所以要将time的值取余,且判断余数为0时,就取1,否则会获取空值报错`.ul.li${time%9!=0?time%9:1}`代码:letrollTime;//定义定时器变量用来清除定时器lettime=0;//转动次数letspeed=300;//转动时间间隔lettimes;//总转动次数//开始按钮点击事件后开始抽奖$("#start").on("click",function(){$("#award").text("");//清空中奖信息times=parseInt(Math.random()
🚀点击这里可直接跳转到本专栏,可查阅顶置最新的华为OD机试宝典~本专栏所有题目均包含优质解题思路,高质量解题代码(Java&Python&C++&JS分别实现),详细代码讲解,助你深入学习,深度掌握!文章目录一.题目-高效货运二.解题思路三.题解代码Python题解代码JAVA题解代码C/C++题解代码JS题解代码四.代码讲解(Java&Python&C++&JS分别讲解)