Python解题 - CSDN周赛第29期 - 争抢糖豆
创始人
2024-05-27 18:47:12
0

本期问哥是志在必得,这本算法书我已经觊觎许久,而之前两次因为种种原因未能如愿。因此,问哥这几天花了不少时间,把所有之前在每日一练做过的题目重新梳理了一遍。苦心人,天不负,感谢官方大大!


第一题:订班服

小A班级订班服了! 可是小A是个小糊涂鬼,整错了好多人的衣服的大小。 小A只能自己掏钱包来补钱了。 小A想知道自己至少需要买多少件衣服。

输入描述:第一行输入一个整数n。(1<=n<=100)表示衣服的数量。 以下n行输入n个尺码。表示订单中衣服的尺码。 接下来n行输入n个尺码。小A订的衣服尺码。 尺码表:M,S,L,XL,XLL,XLLL,XLLLL,XLLLLL。

输出描述:输出至少需要买多少件衣服。

示例:

示例
输入

2

XL
X
M
X

输出1

分析

简单题。需要 n 件衣服,买了 n 件衣服,所以只要把需要的 n 件衣服每种尺码的个数,减去已购买的衣服相应尺码的个数,如果大于0就说明该尺码还需要购买。所以最直接的办法就是用哈希表记录每种尺码的个数,然后再逐个检查。

Python已经提供了内置Counter类,可以自动生成字典,而且支持加减法,连逐个检查这一步都省去了:直接相减,剩下的数字加在一起就是答案。

参考代码

n = int(input().strip())
arr1 = [input().strip() for _ in range(n)]
arr2 = [input().strip() for _ in range(n)]
from collections import Counter
clothes = Counter(arr1) - Counter(arr2)
print(sum(clothes.values()))

第二题:争抢糖豆

抓糖豆,小Q与小K都喜欢吃糖豆。 但是糖豆分两种,超甜糖豆和普通糖豆。 现在有w个超甜糖豆和b个普通糖豆。 小Q和小K开始吃糖豆,他们决定谁先吃到超甜糖豆谁就获胜。 小K每次吃的时候会捏碎一颗糖豆。 小Q先吃,小Q想知道自己获胜的概率。 如果两个人都吃不到超甜糖豆小K获胜。

输入描述:输入两个整数w,b。(0<=w,b<=1000)

输出描述:答案保留9位小数。

示例:

示例
输入1 3
输出0.500000000

分析

也是以前考过的老题了。可以用递归或动态规划来做,但本题的状态转移不太容易一眼发现,所以可能不少人会觉得难。因为问到概率(胜率),所以本质上还是需要用数学来表达。

以动态规划为例(递归容易超时),我们用 dp[w][b] 表示当有 w 颗超甜糖豆,和 b 颗普通糖豆时自己的胜率。因为先吃到超甜糖豆就获胜了,所以自己要想获胜,只能分成两种情况:

  1. 先吃到超甜糖豆,概率是 \frac{w}{w+b}  ,此情况下直接获胜;
  2. 先吃到普通糖豆,但是对手也吃到普通糖豆,所以游戏继续,自己还有获胜的可能。(这里有一个特判的情况:如果只有一颗普通糖豆,而自己先吃到普通糖豆的话,无论如何也是输,后面自然就不用算了。)因此,自己和对手都吃到普通糖豆的概率是 \frac{b}{w+b} * \frac{b-1}{w+b-1}  。(如果一时看不懂可以多琢磨几遍,乘号左边是自己吃到普通糖豆的概率,右边是自己吃完后对方也吃到普通糖豆的概率,看懂了再继续。)

如果没有“捏碎糖豆”的操作,分析到这就结束了,状态转移就是把这两种情况的胜率加在一起,方程如下:

dp[w][b]=\frac{w}{w+b}+\frac{b}{w+b}*\frac{b-1}{w+b-1}*dp[w][b-2]

(因为自己和对手总共吃了两颗普通糖豆,所以上面第二种情况的概率还要乘以 dp[w][b-2] 才是胜率。)

如果上面的内容理解了,我们再来分析“捏碎糖豆”的情况。

捏碎糖豆也有两种情况:

  1. 捏碎了普通糖豆。影响不大,但是上面的第二种状态要接着乘上捏碎普通糖豆的概率,再乘以 dp[w][b-3] 。合在一起的胜率就是 \frac{b}{w+b}*\frac{b-1}{w+b-1}*\frac{b-2}{w+b-2}*dp[w][b-3] 。
  2. 捏碎了超甜糖豆。则二人虽不分胜负,理论上自己还存在胜利的可能(如果还剩下超甜糖豆的话),但是同样地,状态转移方程变了,胜率变成了:\frac{b}{w+b}*\frac{b-1}{w+b-1}*\frac{w}{w+b-2}*dp[w-1][b-2] 。

这两种捏碎糖豆的情况属于同一决策层级,可以加在一起。于是把捏碎糖豆考虑进来,得到最终的状态转移方程如下:

dp[w][b]=\frac{w}{w+b}+\frac{b}{w+b}*\frac{b-1}{w+b-1}*(\frac{b-2}{w+b-2}*dp[w][b-3]+\frac{w}{w+b-2}*dp[w-1][b-2])

此外,如之前所述,还要考虑几个特判的情况:

  1. 没有超甜糖豆,胜率为0,不用计算。
  2. 没有普通糖豆,胜率100%。
  3. 只有一颗普通糖豆,胜率为\frac{w}{w+b} ,因为如果自己先吃到普通糖豆,必输。

很显然,上面第二、三可以合并,而第一条可以在初始化的时候把 dp[0][j],0\leq j\leq b 的时候设置为0。代码如下:

参考代码

w, b = map(int, input().split())
dp = [[0]*(b+1) for _ in range(w+1)]
for i in range(1, w+1):for j in range(b+1):if j <= 1:dp[i][j]=i/(i+j)else:dp[i][j]=i/(i+j)+j/(i+j)*(j-1)/(i+j-1)*((j-2)/(i+j-2)*dp[i][j-3]+i/(i+j-2)*dp[i-1][j-2])
print(f"{dp[w][b]:.9f}")

输出结果的时候要注意,题目要求必须保留9位小数,空位用0补全,所以要设置占位符。


第三题:走楼梯

现在有一截楼梯,根据你的腿长,你一次能走 1 级或 2 级楼梯,已知你要走 n 级楼梯才能走到你的目的楼层,请实现一个方法,计算你走到目的楼层的方案数。

输入描述:输入整数n。(1<=n<=50)

输出描述:输出方案数。

示例:

示例
输入5
输出

8

分析

很明显,答案是斐波那契数列。因为一次只能走 1 级或 2 级楼梯,所以第 n 级阶梯可以由 n-1 级阶梯走过来,也可以由 n-2 级阶梯走过来。如果用函数 f(n) 表示走上第 n 级阶梯的方案数,可得

f(n) = f(n-1)+f(n-2)

因为本题 n 范围较小(1<=n<=50),所以使用递归来做应该也没问题。不过更常用的做法是递推,也算是斐波那契的模板题了。

参考代码

n = int(input().strip())
a = b = 1
for _ in range(n):a, b = b, a+b
print(a)

第四题:打家劫舍

一个小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个房屋存放金额的非负整数数组,计算不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。

输入描述:输入一个正整数n代表房屋的数量(n≤100),接着输入n个非负整数代表每间房屋的现金数量

输出描述:小偷能偷取的最大金额。

示例:

示例
输入4
1 2 3 1
输出4

分析

力扣原题,经典的打家劫舍系列,但凡刷过点题的相信都做过。而且这里选取的是该系列最简单的一道,动态规划入门题,相关题解太多了,这里问哥只简单说两句吧。

因为相邻的房屋不能同时被盗,所以小偷在当前房屋只有两种选择:不偷当前房屋——继承上个房屋可偷取的的最大金额,偷当前房屋——上上个房屋可偷取的最大金额(因为上个房屋不能偷)加上当前房屋的金额,而当前房屋可偷取的最大金额就等于这两种选择中较大的金额。

如果用 f(i) 代表当前房屋可偷取的最大金额,H_{i} 表示当前房屋的金额,可用公式表示如下:

f(i)=max({f(i-1),f(i-2)+H_{i}})

类似斐波那契数列,可以看出 f(i) 仅由 f(i-1) 和 f(i-2) 得到(H_{i} 是给定数组),所以可以使用滚动数组优化空间,换句话说就是只需要额外两个变量循环保存 f(i-1) 和 f(i-2) 的值即可。

参考代码

n = int(input().strip())
arr = [int(item) for item in input().strip().split()]
a = b = 0
for i in arr:a, b = b, max(b, a+i)
print(b)

相关内容

热门资讯

常用商务英语口语   商务英语是以适应职场生活的语言要求为目的,内容涉及到商务活动的方方面面。下面是小编收集的常用商务...
六年级上册英语第一单元练习题   一、根据要求写单词。  1.dry(反义词)__________________  2.writ...
复活节英文怎么说 复活节英文怎么说?复活节的英语翻译是什么?复活节:Easter;"Easter,anniversar...
2008年北京奥运会主题曲 2008年北京奥运会(第29届夏季奥林匹克运动会),2008年8月8日到2008年8月24日在中华人...
英语道歉信 英语道歉信15篇  在日常生活中,道歉信的使用频率越来越高,通过道歉信,我们可以更好地解释事情发生的...
六年级英语专题训练(连词成句... 六年级英语专题训练(连词成句30题)  1. have,playhouse,many,I,toy,i...
上班迟到情况说明英语   每个人都或多或少的迟到过那么几次,因为各种原因,可能生病,可能因为交通堵车,可能是因为天气冷,有...
小学英语教学论文 小学英语教学论文范文  引导语:英语教育一直都是每个家长所器重的,那么有关小学英语教学论文要怎么写呢...
英语口语学习必看的方法技巧 英语口语学习必看的方法技巧如何才能说流利的英语? 说外语时,我们主要应做到四件事:理解、回答、提问、...
四级英语作文选:Birth ... 四级英语作文范文选:Birth controlSince the Chinese Governmen...
金融专业英语面试自我介绍 金融专业英语面试自我介绍3篇  金融专业的学生面试时,面试官要求用英语做自我介绍该怎么说。下面是小编...
我的李老师走了四年级英语日记... 我的李老师走了四年级英语日记带翻译  我上了五个学期的小学却换了六任老师,李老师是带我们班最长的语文...
小学三年级英语日记带翻译捡玉... 小学三年级英语日记带翻译捡玉米  今天,我和妈妈去外婆家,外婆家有刚剥的`玉米棒上带有玉米籽,好大的...
七年级英语优秀教学设计 七年级英语优秀教学设计  作为一位兢兢业业的人民教师,常常要写一份优秀的教学设计,教学设计是把教学原...
我的英语老师作文 我的英语老师作文(通用21篇)  在日常生活或是工作学习中,大家都有写作文的经历,对作文很是熟悉吧,...
英语老师教学经验总结 英语老师教学经验总结(通用19篇)  总结是指社会团体、企业单位和个人对某一阶段的学习、工作或其完成...
初一英语暑假作业答案 初一英语暑假作业答案  英语练习一(基础训练)第一题1.D2.H3.E4.F5.I6.A7.J8.C...
大学生的英语演讲稿 大学生的英语演讲稿范文(精选10篇)  使用正确的写作思路书写演讲稿会更加事半功倍。在现实社会中,越...
VOA美国之音英语学习网址 VOA美国之音英语学习推荐网址 美国之音网站已经成为语言学习最重要的资源站点,在互联网上还有若干网站...
商务英语期末试卷 Part I Term Translation (20%)Section A: Translate ...