自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(4)
  • 收藏
  • 关注

原创 Twenty Questions UVA - 1252

题目传送门思路:这个题目很巧妙啊,一看就是一个状压DP,但是这个题我觉得难点在于如何求得状态转移以后的状态,一开始想了很久都没有想出来,然后看了lrj的书上写的,确实十分的巧妙,我们用dp[s][a]来表示当前已经询问了集合s的问题,具有集合a特征的还要询问最少多少次才能求得最优解,然后我们可以预处理一个数组来记录每一个状态下有多少个满足的物体。#include <algorithm>#inclu

2017-11-20 20:31:25 352

原创 Unidirectional TSP UVA - 116

题目传送门思路:一个点可以往下延伸的状态只有三种,我们可以得出一个递推公式dp[i][j] = min(dp[i - 1][j - 1], dp[i][j - 1], dp[i + 1][j - 1]),dp[i][j]表示在(i, j)这个点上的最小值,但是我们还要求字典序最小的路径,所以我们要对着过程倒序进行,然后记录下来路径。#include <algorithm>#include <cma

2017-11-01 23:38:09 283

原创 Tour UVA - 1347

题目传送门思路:这个题目其实最重要的一点就是把一个人从最左边走到走右边在走回来这个问题转换为两个人同时从最左边走到最右边(除了最左边和最右边的点其余的点只能走一次)。那么我们定义dp[i][j]代表a从起点走到了i,b从起点走到了j的最短距离(1~max(i, j)全部已经走过了),然后只有两个状态转移dp[i + 1][j]或者dp[i + 1][i],我们可以直接求解了。#include <al

2017-11-01 20:17:29 457 1

原创 粉刷匠 BZOJ - 1296

题目传送门思路:这个题先对每一块木板进行DP,dp[i][j]代表前i块木块用j次粉刷的符合要求的最大值,然后在对每一个木板进行一个背包DP就可以了。 PS:这个题目不需要用文件输入输出#include <algorithm>#include <cmath>#include <cstdio>#include <cstring>#include <iostream>#include <li

2017-11-01 10:24:21 579

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除