赛后1min过题\px
Outer space invaders「CERC 2014」 [3]
根据数据范围猜测 dp。先思考过只记一维时间,然后发现这样不太能知道到底哪些时段可行。考虑两维区间dp。记 \(f_{l,r}\) 代表时刻开区间 \((l,r)\) 内的所有进攻者都被消灭的最低成本。注意这里需要 \(l<a,b<r\),也就是完全包含。转移时必然要找到距离最远的一个,然后在某个 \(k\in [a_{max},b_{max}]\) 时刻以 \(d_{max}\) 的功率开放,那所有经过时刻 \(k\) 的进攻者都不需要考虑了,只需考虑 \((l,k),(k,r)\) 范围内的进攻者。于是得到 \(f_{l,r}=\min (f_{l,k}+f_{k,r}+d_{max})\)。这也是为啥使用开区间更方便。
Hack Protection「NEERC 2013」 [3]
枚举右端点,每一位独立考虑。那么 \(\&\) 和一定是先一段 \(0\) 然后一段 \(1\)。把分界线取出来,对每一位的分界线放一起排序,就可以知道每一段的 \(\&\) 的值。然后问题转化为求一段区间内等于某个数的数的个数。直接扫描线+哈希表即可。时空复杂度 \(O(n\log V)\),\(V\) 是值域。
[BZOJ4973]比特战争 [3]
首先不考虑边的限制(这也是我一开始理解的题意)。那么对于一个连通块,显然是找一个最便宜的地方买需求最多的地方的兵的数量。现在加上边的限制那么还需对瓶颈路,也就是最小生成树中最大的边的边权取 \(\max\)。由于这个边权可以特别大,我们还有另一种方法占领整个连通块——对于这条边的两侧分别占领。于是直接kruskal,每次合并时把答案与 \(\min(ans_u+ans_v,\max(w(u,v),\max a_x)*\min(b_x)),x\in S_u\cup S_v\) 取 \(\min\)。其中 \(S_u\) 代表 \(u\) 当前的连通块集合。时间复杂度 \(O(n\log n)\)。
事后检查「ICPC World Finals 2019」 [7]
暴搜+模拟,稍微剪枝即可通过。
标签:连通,12,min,题解,一段,dp,max,模拟
来源: https://www.cnblogs.com/zcr-blog/p/15679019.html
本站声明:
1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。