【题解】"新生赛"长沙理工大学程序设计竞赛

A、Psycho-Pass

全场题,for一遍,然后计数器碰到1就++

B、happy card

一个 \text{DP} 题,对于萌新来讲可以有的难度。
列出所有条件:人数 \mathit n,总的快乐牌 \mathit{num},限制手牌 \mathit m
我们可以 \text{DP} 的是:前 \mathit i 个人在总牌数为 \mathit j 的情况下,第 \mathit i 个人拿 \mathit k 张牌的最大幸福值。想想似乎和01背包有点儿类似,那么状态转移方程也就不难写出来了:

\operatorname{dp}[i][j]=\max (\operatorname{dp}[i-1][j-k]+h[k], \operatorname{dp}[i][j])]当然我们的第一维其实可以直接滚动掉的。。

其实算法还可以再进行时间的优化,将其化为n^2算法。
实际上人数是一个无用条件,我们知道总的快乐牌数,那么人数一定会大于等于这个数。这种情况的所有必要条件就是:总的快乐牌 \mathit{num},限制牌堆 \mathit m ,那么可以化成以下情景:知道总的牌数 \mathit{num},问在限制每堆最大牌数为 \mathit m 时,堆成几堆牌能够使得快乐值最大。其方程式为:
\operatorname{dp}[j]=\max (\operatorname{dp}[j], \operatorname{dp}[j-i]+\operatorname{h}[i]);请大家自行思考原因。

C、7-教417

很简单地模拟一下即可,要求输出最小的数字,那么也就是说当 \mathit 7 最多的时候该数字最小(长度短)。
我们直接\frac{n}{7}就可以知道最多可以放几个 \mathit 7 了,然后往下筛选符合条件的,即扣掉 \mathit x\mathit 7 后的余值模 \mathit 4\mathit 0 。最后把所有 \mathit 4 放在前面,\mathit 7 放在后面。

D、巫妖王的远征

也是比较裸的bfs,就是有些地方比较坑,也属于较简单的题目。我们可以先忽略休息时间,最后做个除法加上就好了。
这里需要注意的是传送门只能一对一,所以我们可以比较方便地使用结构体套map作为地图,用map记录传送门的对应关系,注意是双向的。
然后跑一遍bfs,在bfs中判断一下合法的队首是否存在传送门,然后在判断入队就好了。最后注意特判传送门直接从起点到达终点的情况。

E、括号匹配

这个很简单的,就是个简单的栈的理解运用,用 \mathit {sum} 记录一个数据,在遇到’(‘则加一,遇到’)’则减一,在从前往后扫描的过程中,\mathit {sum} 始终不为负数,并且扫描完成后 \mathit {sum} 等于 \mathit 0 输出 \text{YES} 即可。

F、找朋友

裸的并查集的路径压缩或按秩合并

G、PC快脱单了

看起来也是有点唬人...不过打个表就是一眼题了,我们会发现这就是一个首相为2的斐波那契数列,推出式子:

\operatorname{f}(i)=\operatorname{f}(i-1)+\operatorname{f}(i-2)
证明过程如下:
我们用 \operatorname{dp}[i][j] 表示第 \mathit i 个位置放置 \mathit j ,那么我们很容易得出状态转移方程:
\operatorname{dp}[i][j]=\operatorname{dp}[i-1][k] 若 \mathit j\mathit 0,则 \mathit k 可以为 \mathit 0 或者 \mathit 1,若 \mathit j\mathit 1,则 \mathit k\mathit 0
\begin{aligned} 即:\mathrm{d} \mathrm{p}[\mathrm{i}][1] &=\mathrm{dp}[\mathrm{i}-1][0] \\ \mathrm{d} \mathrm{p}[\mathrm{i}][0] &=\mathrm{dp}[\mathrm{i}-1][1]+\mathrm{dp}[\mathrm{i}-1][0] \\即: \mathrm{dp}[\mathrm{i}][] &=\mathrm{dp}[\mathrm{i}-1][0]+\mathrm{dp}[\mathrm{i}-1][1]+\mathrm{dp}[\mathrm{i}-1][0] \\ &=\mathrm{dp}[\mathrm{i}-1][]+\mathrm{dp}[\mathrm{i}-2][1]+\mathrm{dp}[\mathrm{i}-2][0] \\ &=\mathrm{dp}[\mathrm{i}-1][]+\mathrm{dp}[\mathrm{i}-2][] \\ 证得:& \mathrm{dp}[\mathrm{i}]=\mathrm{dp}[\mathrm{i}-1]+\mathrm{dp}[\mathrm{i}-2] \end{aligned}

H、亚丝娜sama

在原来射出的时间基础上加上 \mathit m,然后做一个前缀和就完事了。

I、洛克王国之域外大逃杀

实际上这题也是很简单,只不过代码量比纯签到题多了一点所以才放到了中等题中...
我们可以先只考虑暴力,也就是先20遍bfs遍历所有的魔物,然后在地图上记录一下每个魔物抵达的时间和该时间点的最大攻击。
接下来由于最多只有两个宠物,我们跑4次bfs就好了,洛克到1号宠物再到2号,洛克到2号再到1号。于是这题就愉快的暴力掉了4000ms+。然后就是考虑优化了。

其实也不需要优化太多,我们可以将所有魔物全部放进队列中一起跑,然后稍微剪个枝就可以过了。我们知道如果一个魔物后抵达A,而它的攻击又弱于或者等于前一个抵达的魔物,那么我们就可以将这个状态给舍弃掉了。1500ms

当然其实还可以再优化的,考虑到没有障碍物的情况,我们可以利用曼哈顿距离做一下操作,我们可以两个队列同时跑,这样我们的宠物能否到达判断就不需要对每个魔物的到达时间和攻击判断,只需要对比一下最大ATK就好了,魔物的队列和之前一样的优化一下就好了,宠物的话利用曼哈顿距离搞搞和之前的写法差别不大。

J、jcc爱踢球

由于每轮都是偶数只队伍,那么这就相当于一颗满二叉树了,我们经常看电视的时候每次比赛都基本会出现树状图。
我们每次只记录叶节点的编号(假设为 \mathit i ),那么下一次的新叶节点编号(即旧叶节点的父亲)为\frac{(i+1)}{2}如图所示:


那么他们相遇也就是父节点相同的时候,而每找一次父节点计数器加一,则最后的计数器的值(记为 \mathit S)就是树的深度-1,也是比赛是场数,最后如果2^S为总的队伍数,则说明决赛相遇。


K、QAQ

此题看起来复杂,但打个表就会发现是个一眼题...
公式由于(i%2)的存在,所以我们只需要计算 \mathit i 为奇数的情况就好了。
那么打个奇数的表就会发现:

f(i, j)=\left\{\begin{array}{l}{1, i=1+4 k(k=0,1 \ldots)} \\ {01 交错, i=3+4 k(k=0,1 \ldots)}\end{array}\right.
那么此题就结束了。

证明如下:
f(\mathit x,\mathit y) 为 \mathit x\mathit y 的所有整数的异或值。
f(2^k, 2^{k+1} -1) (注意文章中的xor 表示“异或”,or 表示“或”):
2^k2^{k+1} -12^k 个数,最高位(+k位)的1个数为 2^k
k \geq 1,则 2^k 为偶数,将这2^k个数的最高位(+k位)去掉,异或值不变。
因而 f(2^k, 2^{k+1} -1) = f(2^k - 2^k, 2^{k+1} -1 -2^k) = f(0, 2^k -1)
因而 f(0, 2^{k+1} -1) = f(0, 2^k -1) \ xor \ f(2^k, 2^{k+1} -1) = 0 (k \geq 1)
f(0, 2^k - 1) = 0 (k \geq 2)
对  f(0, n)\ (n \geq 4) 设 \mathit n 的最高位1是在+k位(k \geq 2)
f(0, n) = f(0, 2^k - 1) \ xor \ f(2^k, n) = f(2^k, n)
2^k\mathit nn+1-2^k 个数,最高位(+k位)共有 m = n+1-2^k 个1,去除最高位的1
\mathit n 为奇数时, \mathit m 是偶数,因而f(0, n) = f(2^k, n) = f(0, n - 2^k)
由于n - 2^k 与 \mathit n 同奇偶,递推上面的公式,可得:f(0, n) = f(0, n \% 4)
当 n \% 4 == 1 时, \operatorname f(0, n) = \operatorname f(0, 1) = 1
n \% 4 == 3 时, \operatorname f(0, n) = \operatorname f(0, 3) = 0

L、这是最难的题

这个题可能就不是那么签到了,需要转一个弯。
我们先对装备的数量排个序,记录一下排序后的前缀和,二分答案记为 \mathit x,检查答案 \mathit x 的时候从后往前遍历,比 \mathit x 大的数是一定满足分配的,
当比 \mathit x 小的时候,我们用此时的前缀和除一下 \mathit x 其值记为 \mathit s,如果 \mathit s 与之前比 \mathit x 大的种类数量的和大于等于 \mathit m ,则改答案为可行答案,继续二分。请大家自行证明其正确性。






全部评论

相关推荐

2025-11-26 11:21
已编辑
武汉理工大学 Java
个人bg: 211本,一段京东实习,一段xhs实习,一段小厂实习。互联网只有美团一个带薪意向。转正失败情况:京东实习了四个月,感觉收获比较少,做的事情偏基础,第三个月底答辩,离职后两个月被告知转正失败。对此我只能说,零售卡硕。xhs实习两个月,反而感觉收获更多,被安排了有挑战的事情,大模型在业务场景中的运用,最后一个星期通知有转正机会,边做需求边匆忙准备,答辩采取一票否决制,四个领导三过一否,也失败。(早知道xhs今年开这么高我就熬夜赶材料了)不过在这个过程中,也push自己了解了一定rag mcp 大模型的相关知识,对于后续面阿里和美团很有帮助。个人基础情况:hot100能默写。去年12底学完jvm juc。2月入职京东前小林coding guide就差不多看完了。后面实习的时候也有继续补面筋,场景题。秋招情况:8月初就投了,也不晚。滴滴: 笔试a了没面,可能投的岗位太小众了?(抱着拿了也不去 用于a价的想法)一直卡着。携程: 不发笔。发官方邮件也不回。京东:笔试挂了。嗯,很耻辱,那天在外面玩但确实很久没复习笔试考试范围了,全忘光了。腾讯:从来没约过,可能暑期面了十几次面太多了。阿里控股:一面挂。阿里国际:hr面后一个月挂。字节:国际电商三面挂->星图一面挂(面的时候已经有很多候选人了)-> 安全风控二面挂(业务不是很好,面试过程说漏嘴说业务会影响我选择,场景题没答好)-> 中台一面后无消息快手:二面挂。xhs:hr面后无消息,排序应该很靠后。虾皮:hr面两个月无消息,应该还在泡池子。百度:一面挂。pdd:笔试a3后笔试挂。难绷。个人反思总结:for 后来者。1. 笔试一定要把握好,虽然面试中都是hot100,有些甚至不考面试题,但是大厂笔试题是有acm难度的,挂了就是挂了,很多没有第二次机会,约面也没机会了。建议时间充裕情况下,还是要把灵神的题单多刷点。顺序可以参考:代码随想录视频+题 -> 灵神视频+题 ->hot100 ->灵神题单(可以每个part挑难度低的前几道写)2. 一段深入长的实习经历一定是大于两段短的,不过现在再让我选到底是继续在jd还是去xhs我还是选不出来。在面试的过程中,有些面试官也会认为我实习的太浅,没有做什么有深度的事情,对多种方案的调研不全面。如果实习做的事情比较有挑战最好,如果没有,也要尽量往多种方案调研最后选择了哪个方案,达到了当初定的业务指标/技术指标方面包装。3. 还是得早投。身边除了bg特别好的朋友,投的晚的无一例外秋招情况会差很多。8月前投能赶上提前批。最晚不要8月中旬过了还没投完。有投的早的没有实习的朋友秋招结果也可以。没有面试的同学一定要尝试官网,boss直聘多种途径投。4. 对于有实习的同学,基础没有那么重要了,更多还是专注于对实习的考察,可以以金字塔的形式进行论述,避免在最开始的时候就展开大量细节。如果实在没有实习,bg够硬,投的够早也会有面,只需要一个比较深入的项目应该就没问题,把项目当作自己在实习要投入生产的心态去调研包装。5. 有的时候真的看运气。即使是同一个部门甚至是同一个组的同学,做的事情也会有差异,这主要看导师被分配到什么样的活。for me:大二的时候绩点排名前10%,但还是决定放弃保研,开始学java,这一路走来,经历迷茫踏实的反复,也想和自己说句幸苦了,谁想得到当初给自己定的目标是有份工作不饿死就行。可能差点运气,可能在关键节点上做的还是不够,对于实习的包装,对于面试表现还是差点。会后悔自己没读研吗?其实我也有考雅思,申请了港大计算机,但估计大概率还是工作(实则也没港大offer)。人不能既要又要还要,我不能既要早点工作赚钱,实现我财富自由支配,带不舍得花钱的家人去旅游的想法,又要长期来看高学历晋升的优势,还要在大环境变差一届比一届卷我也能找到差强人意的工作。所以,至少现在,我不后悔。如果我更倾向于国企而不是互联网,比起技术挑战更偏爱稳定的生活我大概率会读研。如果我本科没有211,我还想进大厂,我也大概率会读研。会后悔自己没选其他的方向吗?java确实相对卷一点,但也只是相对的,因为其他方向的人也很多,并不是换方向就一定会更好。计算机这一行本就短命,能干到35就算成功,大家都是为了赚钱,基于此,在背景没那么硬时,选择一个相对人少的方向进大厂是对的。看自己怎么理解了。最好的还是参考直系学长学姐的选择,一定要多沟通交流。一些安慰自己的话,秋招是人生的起点,不一定是高费阵容才能吃鸡,低费阵容早点发育也有吃鸡的上限。(随便乱说的)。最后还想再写一段话给学妹们,程序员这一行,女生确实会相对少一点,但比起传统工科非常直接的偏向男生,计算机这一行认为菜是原罪,性别的因素会少很多,更多看个人技术和水平。在京东实习的时候,我的小组长在我进去第一天就和我说,我们部门女生虽然少,但是水平都至少是中上的,都很能吃苦很能干。无论是我们组干活巨快的A姐,还是总能很快解答我问题的B姐,又或者是其他总能给我提供建议的其他姐姐们,都使我对这一点坚信不疑,她们高学历,专业,细心,耐心。如果你也热爱技术,虽然有时会被bug折磨,但喜欢学到知识时候的踏实,喜欢bug fix的爽感,你就是适合这一行的。我的秋招结束了,但我大概率不会甘心,还是会想试试春招,但我也真的觉得到现在这一步已经很棒了。欢迎同校学妹学弟们找我沟通交流~
疲倦的牛马还在上班:再冲一次,春招不留遗憾吧!
我的秋招日记
点赞 评论 收藏
分享
评论
4
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务