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之和为素数,且没环和重边

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


472D(水)

构造一棵树,使得该树中各点对的距离与给出原矩阵的距离相等

不知道为什么,在纸上画了一下就觉得是MST,然后暴力dijkstra检查匹配与否

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


242C(疑)

想了一下没找到快速有效的表示方法,网上题解甚至敢1e9logn暴力
暂时搁置


954D

给了n个点和m条边,还给了起点s和终点t,问最多加多少条边,可以使得起点到终点的最短路不会变小。

分开两边求sssp,然后枚举不存在的边的两个dis的可能性
\(dis1[i]+1+dis2[j]≥dis1[ed] \ \& \ dis2[i]+1+dis1[j]≥dis2[st]\)


543B

给定一个无向边无权图,给出两个起点\(s_i\)终点\(t_i\)和约束条件\(l_i\)
求最多删除的边数使得\(dis[s_1][t_1]≤l_1 \ \& \ dis[s_2][t_2]≤l_2\)
首先无相关的边(不在最短路径上的边)肯定是要被叉的
其次最短路径上的边也是可能被叉的,但这时候叉的某一路径可能会影响到两条最短路径
因此暴力枚举共享的端点,计算出当前最短路径下的总边数更新答案(注意枚举是有向的)
也可以想象成不断添加边构成新的符合约束的最短路
https://paste.ubuntu.com/p/PHrBpfXp9y/


25C(水)

给定一个图,每次添加一条边,对所有最短点对距离和

改动floyd,每次只\(O(n^2)\)更新相关的点

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


229B(水)

普通sssp,存在限制:某时刻某些节点不可经过

每次访问节点时先计算出连续被屏蔽的时间长即可

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


61D

给定一棵树,求从点1到各点的边权和最小

贪心的做法,找出起点为1的最长的路径,剩下的边都遍历2遍

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


877D(水)

从起点开始可往四个方向跑,每个方向可走1-k步(障碍物除外),问到达终点的最小时间

预判要走的方向,如果该方向上存在比当前时间还短的状态就无需往后(i-k)搜索

实现上可能有坑,不敲了


14D

给出一棵树,找出两条不相交即没有公共点的路径,使得两个路径的长度的乘积最大。

枚举树中的边,将该边去掉,分成两棵树,分别求出这两棵树的直径,乘起来维护一个最大值即可。


938D

给定一个图,图的自定义终点有点权,求每一个起点到某一个终点的最小点权边权和(其中边要往返,既乘2)

多个源点不定终点看着有点难办,要尝试倒着求,给每个点的连接到汇点\(S\),边权为该点的点权,然后剩余的边权全部乘2

那么从S出发的SSSP就是对应的原题过程的逆过程,由此解得

PS.本题存在代码歧视,差不多一样的写法愣是MLE个10倍艹,不提供代码了


SP Last UPD:7.3

Codeforces - tag::graphs 大合集 [占坑]的更多相关文章

  1. Codeforces - tag::dp 大合集 [占坑 6 / inf]

    Gym - 100753J 某国家仅有金币和银币两种货币,起汇率为g,纪念品市场有n个商人和商品,商人结帐只用银币,并且把一堆银币装在袋子里,分为三种类型,分别按向下/向上/四舍五入取整(其中向上的优 ...

  2. Codeforces - tag::flows 大合集 [完坑 x14]

    589F 题意:给出n个时间区间,每个区间挑定长的非连续区间,求不同个区间不存在时间冲突的最大定长,输出乘上n 二分图模型+二分长度,左顶点集为区间编号,右顶点集为时间编号(1...10000),汇点 ...

  3. Codeforces - tag::data structures 大合集 [占坑 25 / 0x3f3f3f3f]

    371D 小盘子不断嵌套与大盘子,最后与地面相连,往里面灌水,溢出部分会往下面流,求每次操作时当前的盘子的容量 其实这道题是期末考前就做好了的.. 链式结构考虑并查集,然后没了(求大佬解释第一个T的点 ...

  4. HDU - tag :: Multi-University 大合集

    说明:按无序更新,只更(会)水题 4632 题意:求字符串的回文子[序列]个数 区间DP,设\(dp[i][j]\)为\([i,j]\)范围内的回文子序列个数, 由容斥定理可得\(dp[i][j]=d ...

  5. ubuntu 18.04 搭建flask服务器(大合集,个人实操)

    ubuntu 18.04 搭建flask服务器(大合集) Ubuntu python flask 服务器 本次使用的Ubuntu版本为:Ubuntu 18.04.5 LTS (GNU/Linux 4. ...

  6. Lucene搜索方式大合集

    package junit; import java.io.File; import java.io.IOException; import java.text.ParseException; imp ...

  7. 【收藏】Java多线程/并发编程大合集

    (一).[Java并发编程]并发编程大合集-兰亭风雨    [Java并发编程]实现多线程的两种方法    [Java并发编程]线程的中断    [Java并发编程]正确挂起.恢复.终止线程    [ ...

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

    1.前言 大合集总共14道题,出自江哥之手(这就没什么好戏了),做得让人花枝乱颤.虽说大部分是NOIP难度,也有简单的几道题目,但是还是做的很辛苦,有几道题几乎没思路,下面一道道边看边分析一下. 2. ...

  9. [题解+总结]NOIP动态规划大合集

    1.前言 NOIP2003-2014动态规划题目大合集,有简单的也有难的(对于我这种动态规划盲当然存在难的),今天就把这些东西归纳一下,做一个比较全面的总结,方便对动态规划有一个更深的理解. 2.NO ...

随机推荐

  1. ofo开锁共享平台

    http://www.cnblogs.com/mengyu/p/7700980.html

  2. Reading——简约至上

    读书感言: 简约至上——Giles Colborne,我去,这是哪里来的渣书,通篇都是泛泛而谈,实在受不鸟了> <,没学到啥实质性的东西,论述一大堆.!!!还姐的20多块钱.最讨厌这样的书 ...

  3. Thinkphp 导出大量数据 csv格式

    public function test2() { $user_count = M('department')->count(); $page = ceil($user_count / 1000 ...

  4. firefox ubuntu 中文包

    sudo apt-get install firefox-locale-zh-hans

  5. Java设置jre通过java new Date()得到的时间的时区

    1.前提 由于公司有印尼的项目,该项目仅对印尼当地开放使用(公司在国内,用的是阿里云的ECS,但是阿里云在印尼没有服务器,所以就买了新加坡的服务器),印尼当地人用的是东七区的时间,所以比国内东八区的时 ...

  6. js 格式化时间

    //格式化时间 function time_format(time) { return new Date(parseInt(time) * 1000).toLocaleString().replace ...

  7. Linq善解人意之通过MSDN对14个“查询关键字“逐个解剖

    linq中存在的 14个关键字 网址: https://msdn.microsoft.com/zh-cn/library/bb310804.aspx from: 迭代变量 where:对数据源进行逻辑 ...

  8. [LeetCode 题解]: Search a 2D Matrix

    Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...

  9. .Net程序随系统开机启动(仿Foxmail托盘效果控制)

    对于使.NET程序随系统开机启动,最常用的可能就是向在注册表中注册开机启动项,或是建立Windows服务,使程序随系统启动而启动.这里以WinForm程序为例,测试Demo分享,同时附上对于程序托盘的 ...

  10. C# javascript 采用 RSA 加密解密

    C# javascript 采用 RSA 加密解密 1.C#提供公钥 2.javascript用公钥加密 3.C#用私钥解密 4.javascript 类库 https://www.pidder.de ...