Codeforces - Tag::SP 大合集 [占坑]

完蛋了要挂科了,赶紧更新个专题冷静一下

PS.仅按A题人数顺序更新,选择性忽略部分题

PPS.这个专题应该比较休闲吧

520B

给定初始n和目标m,存在两种操作\(-1\)和\(×2\),要求最少操作次数

无脑解法是BFS,不能解决稍大的规模

当n>m时,输出n-m

否则逆向处理,转换为m到n的最小操作次数,存在两种操作\(+1\)和\(/2\)(后者只能在偶数时操作)

由\((m+1+1)/2=m/2+1\)得尽量多的/2操作可以减少操作次数

因此若操作当前的\(m?\)是偶数时尽量/2,直到\(m≤n?\)时再多操作\((n-m)?\)次\(+1?\)是最优操作

Challenge: suppose we have a generalized problem: we want to get n starting from m using two operations "subtract a" and "multiply by b". Generalize the solution to find the minimal number of moves to get from n to m in time if a and b are coprime. Can you do it if a and b may have common divisors greater than 1?


339C

给出砝码,限定重量类型但个数无限,求能否在天平上按照规则操作\(m\)次并输出方案

规则1.每次使用的砝码不能与上一次的相同重量

规则2:每次放入砝码后该侧的重量比另一侧天平的重量大

我的想法:设\(dp[i][j][k]\):第\(i\)次放入重量为\(j\)的砝码使另一侧的天平为\(k\)

\(dp[i][j][k]=dp[i-1][x≠j][y<sum...]\)

但官方题解用到了平衡的想法来替代sum

那么\(dp[i][j][k]\):存在第\(i\)次放入重量为\(j\)的砝码使两侧平衡差为\(k\)的方案

\(dp[i][j][k]=dp[i-1][x≠j][y=j-k>0]\) ,只需存在一对\((x,y)\)该方程既为真

说明:记上一次平衡差为\(y\),假设砝码放在左边,则\(l-r=y\)

这次在右边平衡差为\(k\),则\(r‘-l‘=k,l‘=l,r‘=r+j\)

\(∴y=j-k\)


295B

给定一个图,顶点数\(n≤500\),图中每对顶点都有两条边分别指向从对中某一点指向另一点,且权值给出

再给定一个删除序列\(x[1...n]\),表示要按顺序删除某个点,求每次序列操作前剩余的所有点对的最短距离之和

逆向思维,考虑floyd三重循环最外层为加入顶点的顺序,那我们把删除序列翻转过来就变为添加序列,既是一个floyd的过程

实现细节上的注意,添加\(x[k]\)点后先把\(x[k]\)相关的所有边都优先松弛再进行内循环更新

PS.做完这道题后对floyd的细节有了船新的认识

https://paste.ubuntu.com/p/YVHzf8pk8R/


329B(水)

从起点走到终点,其中有些地方不能走,有些地方存在一些敌人(0~9),且能和我们一样正常移动或者是停留,每次动作都是一个单位的时间,而敌人总是尽量杀向你。求起点到终点能最少干掉敌人的数目。

要注意到的一点是必然能拦截自己的肯定是它们到终点的距离小于自己到终点的距离

然后从终点BFS就ok了


916C(水)

构造一个n个点m条边的图,使得其1到n最短路距离为素数,MST之和为素数,且没环和重边

很显然构造一条链凑数就好



Last UPD:7.1

原文地址:https://www.cnblogs.com/caturra/p/9249243.html

时间: 2024-11-13 18:27:35

Codeforces - Tag::SP 大合集 [占坑]的相关文章

HDU - tag :: Multi-University 大合集

说明:按无序更新,只更(会)水题 4632 题意:求字符串的回文子[序列]个数 区间DP,设\(dp[i][j]\)为\([i,j]\)范围内的回文子序列个数, 由容斥定理可得\(dp[i][j]=dp[i+1][j]+dp[i][j-1]-dp[i+1][j-1]\) 如果\(i\)和\(j\)本身就可以构成回文,那就多增加\(dp[i+1][j-1]+1\)个回文子序列(1代表只含\(i,j\)的子序列) https://paste.ubuntu.com/p/Sjh9c9K9H7/ 6315

css font-family字体大合集

CSS font-family字体大合集 在写文字内容占大篇幅的页面是,总是会面临着改变字体的需求,以下为font-family常用合集以及一部分文字效果: windows常见内置中文字体 字体中文名             字体英文名                                效果实例 宋体                      SimSun(浏览器默认)             夏目友人帐/ABCDEFG 黑体                      SimHei 

[题解+总结]动态规划大合集II

1.前言 大合集总共14道题,出自江哥之手(这就没什么好戏了),做得让人花枝乱颤.虽说大部分是NOIP难度,也有简单的几道题目,但是还是做的很辛苦,有几道题几乎没思路,下面一道道边看边分析一下. 2.lis 最长上升子序列 唯一一道裸题,但是O(n^2)过不了,临时看了看O(n log n)的二分做法和线段树做法.先来讲讲简单的二分做法,其本质就是在O(n^2)上进行优化,需要证明一个结论.设当前处理数列第k位,存在: (1)a[i]<a[j]<a[k]: (2)i<j<k: (3

[知识点]NOIP动态规划大合集

1.前言 NOIP2003-2014动态规划题目大合集,有简单的也有难的(对于我这种动态规划盲当然存在难的),今天就把这些东西归纳一下,做一个比较全面的总结,方便对动态规划有一个更深的理解. 2.NOIP2003 加分二叉树 树形DP入门题,根据题意,一个树的加分=左子树*右子树+根节点,由此可以设f[i][j]为子树i到j的加分,则有方程:f[i][j]=max{d[t]+f[i,t-1]*f[t+1,j]} ( t∈[i,j] ) 3.NOIP2004 合唱队形 应该是最简单的一道了,枚举队

从零开始学数据分析,什么程度可以找到工作?( 内附20G、5000分钟数据分析工具教程大合集 )

从零开始学数据分析,什么程度可以找到工作?( 内附20G.5000分钟数据分析工具教程大合集 ) 我现在在Coursera上面学data science 中的R programming,过去很少接触过统计.计算机这两个学科,现在很想转行做数据.问题如下: 1.Data需要学到什么程度可以找工作?2.初级的数据分析会做哪些工作?3.数据分析有什么小方向吗?4.想要深度做数据分析有怎样的建议? 5.统计的学习应该从哪里下手? 本文将给你以上问题所有答案,文末还有UniCareer为大家独家整理的20

Lucene搜索方式大合集

package junit; import java.io.File; import java.io.IOException; import java.text.ParseException; import java.util.ArrayList; import java.util.List; import org.apache.commons.lang.math.NumberUtils; import org.apache.lucene.document.Document; import or

Android 软件开发与游戏开发1 至 32系列博文大合集

Android 软件开发与游戏开发1 至 32系列博文大合集Android 软件开发与游戏开发1 至 32系列博文大合集 http://www.qdmm.com/BookReader/17958,65822595.aspxhttp://www.qdmm.com/BookReader/17958,65822597.aspxhttp://www.qdmm.com/BookReader/17958,65822598.aspxhttp://www.qdmm.com/BookReader/17958,65

Android软件开发之盘点所有Dialog对话框大合集

对话框大合集 今天我用自己写的一个Demo 和大家详细介绍一个Android中的对话框的使用技巧. <ignore_js_op> 1.确定取消对话框 对话框中有2个按钮   通过调用 setPositiveButton 方法 和 setNegativeButton 方法 可以设置按钮的显示内容以及按钮的监听事件.<ignore_js_op> 我们使用AlerDialog 创建对话框 AlertDialog.Builder builder = new AlertDialog.Buil

python字符串操作实方法大合集

python字符串操作实方法大合集,包括了几乎所有常用的python字符串操作,如字符串的替换.删除.截取.复制.连接.比较.查找.分割等,需要的朋友可以参考下: #1.去空格及特殊符号 s.strip().lstrip().rstrip(',') #2.复制字符串 #strcpy(sStr1,sStr2) sStr1 = 'strcpy' sStr2 = sStr1 sStr1 = 'strcpy2' print sStr2 #3.连接字符串 #strcat(sStr1,sStr2) sStr