------动态规划--------
Fb_by
这个作者很懒,什么都没留下…
展开
-
UVA 11552 Fewest Flops 【区间dp】
题意:将一个字符串分成若干块,每块大小为k,保证串的长度是k的倍数。每块的元素可以任意摆放,但是块与块之间的位置不变。摆放完后,将连续相同的字符看成一个,问最少多少个。分析:定义dp[i][j]为第i块以该块的第j个元素结尾。状态转移:dp[i][j]=min(dp[i][j],dp[i-1][p]+cnt-1);//如果前一块以p结尾,而第i块不以p结尾,那么这里就可以合并一种字原创 2016-03-29 16:02:25 · 242 阅读 · 0 评论 -
Codeforces Round #343 (Div. 2)
链接:http://codeforces.com/contest/629A. Far Relative’s Birthday Cake题意:计算每行每列中的c有多少对。分析:n*(n-1)/2.。。代码:#include#include#include#include#include#include#include#include#include#includ原创 2016-03-17 20:09:40 · 284 阅读 · 0 评论 -
第五届华中区程序设计邀请赛 网络赛Calculation E 【状压dp】
链接:http://acm.whu.edu.cn/land/problem/detail?problem_id=1608题意:把n个数分成若干堆(一个数只能在一堆),若一堆经过+or-操作等于m,ans+1,问最大的ans。分析:n只有14,我们考虑状压,可以知道哪些数在一个集合(s)得到和sum[s],然后我们可以枚举s的子集(s0),当sum[s]或sum[s]-sum[s0]-sum原创 2016-04-10 17:56:33 · 304 阅读 · 0 评论 -
BestCoder Round #77
链接:http://bestcoder.hdu.edu.cn/1001:子集异或和,n=1不为0其他都为0。代码:#include#include#include#include#include#include#include#include#include#include#include#define INF 0x3f3f3f3f#define Mn 105原创 2016-03-27 22:03:46 · 266 阅读 · 0 评论 -
hdu5001 walk 【概率dp】
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5001题意:给你一个n个点m条边的无向图,问你任意从一的点出发走d步后,不经过某个点的概率,输出那个点的概率。分析:枚举一个点,表示不从该点出发经过该点的概率,因为从该点出发的路径,一直都是经过该点的,比如说到a点的概率是p1,它如果连两个点那么ans=p1+p1*0.5+p1*0.5这里我们就原创 2016-07-25 15:41:25 · 226 阅读 · 0 评论 -
hdu1520 Anniversary party 【树形dp】
链接:http://acm.hdu.edu.cn/showproblem.php?pid=1520题意:给你一棵树,每个点都有权值,现在要你选一些点,这些点与父亲不能同时选,问权值最大多少。分析:树形dp入门题,直接用dp[i][0/1]表示第i个节点选或不选,转移:dp[u][0]+=max(dp[v][0],dp[v][1])dp[u][1]+=dp[v][0]代码:#原创 2016-07-26 21:04:54 · 188 阅读 · 0 评论 -
hdu2196 Computer 【树形dp】
链接:http://acm.hdu.edu.cn/showproblem.php?pid=2196题意:有n台电脑,通过n-1条网线连接,问每台电脑到离他最远的距离是多少。分析:我们把这些电脑看成一棵树,可以很容易的得到每个点的子树最远的距离(a),我们发现某个节点的答案就是max(a,除下它所在子树后父亲最远的距离)。所以我们可以先dfs一遍存下每个点(u)的子树离他最远和次远距离,原创 2016-07-27 12:38:24 · 226 阅读 · 0 评论 -
cf 135div2D Choosing Capital for Treeland 【树形dp】
链接:http://codeforces.com/problemset/problem/219/D题意:n个点,m个有向边,现在要你求出每个点作为根使得图为一棵树需要改变多少边的方向,输出最少改变多少次,和这些点。分析:建图时发现,一个点为根时他的出度边不用改变,所以将所有的入边的权值为1,然后用dfs统计每个点的子树有多少这样的边。我们还可以发现,一个点(u)和他的父亲(fa)的关系原创 2016-07-27 14:20:52 · 216 阅读 · 0 评论 -
poj1155 TELE 【树形dp】
链接:http://poj.org/problem?id=1155题意:以1为根的树,叶子节点上有权值,从1出发到叶子节点会得到叶子的权值,但是要减去路径上的权值,问你最多到达多少叶子使得最后的值大于等于0.分析:i点为根时用到的叶子节点j的价值用dp[i][j]表示,向上更新的时候就相当于将子树合并。dp[u][j+k]=max(dp[u][j]+dp[v][k]-w).代码:原创 2016-07-27 17:15:56 · 262 阅读 · 0 评论 -
CF355div2
链接:http://codeforces.com/contest/677c:Vanya and Label题意:给你一个字符串s,每个字符可以用一个10进制数表示(0~63),现在要求有多少对与s长度一样的字符串通过&得到s。分析:只用64个数,直接暴力出每两个数的&,然后相乘就行了。#include#include#include#include#include#i原创 2016-07-06 21:10:40 · 402 阅读 · 0 评论 -
poj2955 Brackets 【区间dp】
链接:http://poj.org/problem?id=2955题意:给你一串由“( )”“[ ]”组成的括号串,现在问你最多的括号匹配。分析:枚举一个长度,看看这个区间内有多少能匹配的括号,用dp[i][j]表示,s[i]和s[j]能匹配时dp[i][j]=dp[i+1][j-1]+2,然后枚举区间内的点,两段区间合并就可以找到最大的匹配。代码:#include#incl原创 2016-07-18 16:16:04 · 200 阅读 · 0 评论 -
nyoj746 整数划分(四)【区间dp】
链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=746分析:a[i][j]表示i到j的数,dp[i][j]表示,长度为i插了j个乘号的最大值,转移:dp[i][j]=max(dp[i][j],dp[k][j-1]*a[k+1][i]) 表示在k的位子插一个乘号。代码:#include#include#include#原创 2016-07-18 16:27:50 · 472 阅读 · 0 评论 -
poj1651 Multiplication Puzzle 【区间dp】
链接:http://poj.org/problem?id=1651题意:有n个数,现在要删除【2,n-1】里的数,每次删除的代价是它和左边右边的乘积,求出最少代价。分析:dp[i][j]表示删除了(i,j)的某个数的最小代价,转移方程: dp[i][j]=min(dp[i][j],dp[i][k]+dp[k][j]+a[i]*a[j]*a[k]); k为枚举要删除的数。代码:#in原创 2016-07-18 16:33:53 · 201 阅读 · 0 评论 -
hdu5823 color II 【状压dp(非正解)】
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5823题意:有n(n现在要你求出这个图的所有非空真子集需要最少的颜色将所有点染色,相连的两个点颜色不能一样。分析:如果一个集合s的子集s0是一个独立集,那么s最少的颜色就不是由s0决定,但是可以由s-s0求出。dp[s]=min(dp[s],dp[s-s0]+1)。代码:#inclu原创 2016-08-12 13:33:00 · 386 阅读 · 0 评论 -
bzoj 2064: 分裂【状态压缩】
链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2064题意:将n个数以最少操作变成m个数,操作为合并分解。分析:前后数的总和不变,我们可以将n个数合并成一个数,然后分解成m个数,操作数是n+m-2,但是有些数是不用合并的,枚举n和m的子集,每有一对相等ans-2.这时我们取n的为正数,m的为负数。代码:#include#原创 2016-03-28 14:46:11 · 597 阅读 · 1 评论 -
UVA 10534 Wavio Sequence 【LIS】
题意:找出一个最长的奇数序列长度2k+1,要求前k+1个递增后k+1递减。分析:正反跑两遍LIS然后取min找出合法序列,最后找最长的。#include#include#include#include#include#include#include#include#include#include#include#define INF 0x3f3f3f3f#defin原创 2016-03-28 14:32:27 · 273 阅读 · 0 评论 -
codeforces 645 D Robot Rapping Results Report 【树形dp】
链接:http://codeforces.com/problemset/problem/645/D题意:给你n个人,和m条关系(有传递性),输入a b代表a比b的等级大,问你最少用到前多少条关系可以确定唯一的关系顺序。不能输出-1。分析:题意说了不会有两个在同一等级,所以不存在环,且入度为零的点不唯一输出-1。由于不存在环,所以我们可以在图中找到最长链(一定唯一,包含所有节点),在找最长链原创 2016-04-08 21:23:16 · 466 阅读 · 0 评论 -
UVA 11404 Palindromic Subsequence 【LCS】
题意:给你一个字符串,要你删除一些字符让剩下的字符组成尽量长的回文串。分析:将原串反转下,然后和原串求一边LCS,顺便把字典序最小的存下来,但是这个串并不一定是回文串,但是我们可以确定他的前一半一定是回文串的前半部分。最后注意长度的奇偶。代码:#include#include#include#include#include#include#include#includ原创 2016-03-30 20:52:01 · 301 阅读 · 0 评论 -
UVA 10891【区间dp】
题意:给定n个数字,A和B可以从这串数字的两端任意选数字,一次只能从一端选取。并且A B每一步走的都是最优的。在A先选择的情况下,求A,B最后差值最大是多少。分析:无论怎么取,剩下的序列都是原序列的连续子序列。将这个区间可以分割成若干对区间,找出这些区间的最小值,剩下的就是a在当前所取最大值。转移方程为:dp[i][j]=sum[j]-sum[i-1]-min(dp[i+1][原创 2016-03-23 22:27:04 · 269 阅读 · 0 评论 -
UVA 11825【状态压缩】
题意:有一个由编号0~n-1的n台计算机组成的网络,一共有n种服务,每台计算机上都运行着全部服务,对于每台计算机,你可以选择停止一项服务,这个行为会导致与这台计算机和与他相连的其他计算机上的这项服务都停止(原来已经停止的继续保持停止状态)。求最多能使多少个服务瘫痪(即没有任何一台计算机在运行这项服务)。分析:用2进制表示每台电脑的集合有哪些电脑a[i],将这些集合用位运算求出若干a[i原创 2016-03-23 22:42:50 · 355 阅读 · 0 评论 -
UVA 10859【树形dp】
题意:给你一个n个点m条边的无向无环图,每个节点都可以放灯。每盏灯将照亮以它为一个端点的所有边。在所有边都被照亮的前提下,求灯的总数最小数,被两盏灯同时被照亮的边数应该尽量大的灯数。分析:将问题转换成灯的总数(a)最小,被一盏灯照亮的边数(b)应该尽量小。将这两个取小值合并成一个问题,引入一个大值M,x=a*M+b,这时x最小时,a=x/M最小,且b=x%M最小。这时只要求最小的x原创 2016-03-24 18:21:55 · 315 阅读 · 0 评论 -
UVA 1169 【单调队列优化dp】
题意:给出机器人的最大负重c,和n个垃圾,接下来n行代表垃圾的坐标和重量w,一开始机器人在原点,机器人只能走横竖,机器人可以拿多个垃圾,只要不超过最大负重,然后放回垃圾桶,垃圾桶在原点,问机器人将所有垃圾放到垃圾桶最少需要走的距离。分析:定义dp[i]表示,前i个垃圾放回垃圾桶的最短距离。转移方程为:dp[i]=min(dp[j]+dis0[j+1]+sumdis[i]-sumdi原创 2016-03-24 21:15:22 · 368 阅读 · 0 评论 -
UVA 1099【状态压缩】
题意:有一块x*y的巧克力,问你是否可以分成n块大小分别为aI的小巧克力分析:n然后枚举s的子集,判断子集能否构成。代码:#include#include#include#include#include#include#include#include#include#include#include#define INF 0x3f3f3f3f#define M原创 2016-03-24 21:41:31 · 538 阅读 · 0 评论 -
uva10635 【LIS】
题意:求两个数组的最长公共子序列长度(LCS),每个序列中的元素没有重复的且取值范围1~n*n。分析:直接求LCS时间复杂度为o(n*n)肯定不行,考虑题目的特殊性,数的范围1~n*n,且任意两个数都不相同。如果把第一个数组重新编号:12,3,4...p+1。把第二个数组也对应起来,实际上问题就转化为了求第二个数组的LIS(可以用o(nlgn)的算法求解。问题就得到了解决。代码:#原创 2016-03-21 22:09:44 · 270 阅读 · 0 评论 -
UVALive 4731 Cellular Network 【dp】
#include#include#include#include#include#include#include#include#include#include#include#define INF 0x3f3f3f3f#define Mn 105#define Mm 200#define mod 1000000007#define CLR(a,b) memset((原创 2016-04-06 22:53:56 · 305 阅读 · 0 评论 -
BestCoder Round #78 (div.2)
B:DP题意:n个数中取若干数的GCD,求所有不同取法的GCD和。分析:我们令dp[i][j]表示在前i个数中,选出若干个数使得它们的gcd为j的方案数,于是只需要枚举第i+1个数是否被选中来转移就可以了令第i+1个数为v,当考虑dp[i][j]的时候,我们令dp[i+1][j] += dp[i][j]dp[i+1][j]+=dp[i][j](v 不选),dp[i+1][gcd(j,v原创 2016-04-06 22:58:15 · 273 阅读 · 0 评论 -
UVA 11584 【简单dp】
题意:求一个字符串最少由多少个回文串组成。分析:定义dp[i][j]前i由多少回文串组成。转移方程dp[i]=min(dp[i],dp[j-1]+1).代码:#include#include#include#include#include#include#include#include#include#include#include#define INF 0x3f原创 2016-03-26 15:18:48 · 318 阅读 · 0 评论 -
UVALive 4256 Salesmen 【简单dp】
题意:给你一棵树,和一串序列,求最少改变多少个数使得序列中的每个相邻的数要么相等要么在树上相邻。分析:设状态dp[i][j]表示长度为i以j结尾最少修改几次合法。转移dp[i][k]=min(dp[i][k],dp[i-1][j]+(a[i]!=k)) k是当前最后数字,j是k前一个,j可以等于k(处理与前面相等),若j与k在树上相邻,判断a[i]!=k,dp[i][k]+1;代码:原创 2016-03-26 15:30:21 · 283 阅读 · 0 评论 -
UVA 11795 Mega Man's Mission 【状压dp】
题意:有n+1个01串,第一个代表已经有了可以消灭某些人的武器,每个武器只能杀死特定的机器,接下来n行代表,每消灭一个机器人将会得到他的武器。 问可以消灭所有机器人的顺序方案总数。分析:n很小,可以用二进制存下每种枪的状态,考虑状压dp。设dp[s]表示能消灭的人的状态s的方案数。dp[s]+=dp[{s-1}];//s状态可以由s少了其中为1的一位的状态杀掉这一位得来。代原创 2016-04-08 20:55:11 · 308 阅读 · 0 评论 -
UVA 1452 Jump 【约瑟夫环】
题意:约瑟夫问题变形,输出最后三个人。分析:最后一天只有1个人(s1=0),到第二天s1=(s1+k)%2=k%2,这时第二天的人(s2)也可以确定了s2=(s1+1)%2=(k+1)%2,这时s3=2。代码:#include #include #include #include #include #include #include #include #include原创 2016-04-08 21:05:03 · 281 阅读 · 0 评论 -
hdu5816 Hearthstone 【状压dp】
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5816题意:对方有p滴血,你的牌库有n张A牌,m张B牌;A牌的效果是再抽两张牌,B牌的效果对对方造成xi滴血伤害。你现在手牌为空,现在可以抽一张牌,问一回合打败对手的概率。分析:n+m假设通过A牌我们已经抽了x张A牌,y张B牌,那么我们可以知道接下来还能不抽牌:判断还有没有A牌剩余 x*2原创 2016-08-13 17:29:02 · 388 阅读 · 0 评论