Travel(HDU 4284状压dp)
题意:给n个城市m条路的网图,pp在城市1有一定的钱,想游览这n个城市(包括1),到达一个城市要一定的花费,可以在城市工作赚钱,但前提有工作证(得到有一定的花费),没工作证不能在该城市工作,但可以走,一个城市只能工作一次,问pp是否能游览n个城市回到城市1.
分析:这个题想到杀怪(Survival(ZOJ 2297状压dp)
那个题,也是钱如果小于0就挂了,最后求剩余的最大钱数,先求出最短路和
Hie with the Pie(POJ 3311状压dp)
送披萨那个题相似。
#include <map>
#include <set>
#include <list>
#include <cmath>
#include <queue>
#include <stack>
#include <cstdio>
#include <vector>
#include <string>
#include <cctype>
#include <complex>
#include <cassert>
#include <utility>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std;
typedef pair<int,int> PII;
typedef long long ll;
#define lson l,m,rt<<1
#define pi acos(-1.0)
#define rson m+1,r,rt<<11
#define All 1,N,1
#define read freopen("in.txt", "r", stdin)
#define N 1<<16
#define INF 99999999
const int mod = 1000000007;
int n,m,money,tn;
int dp[N][20],cost[120][120];
struct city{
int in,c,d;
}t[20];
void floyd(){
for(int k=1;k<=tn;++k)
for(int i=1;i<=tn;++i)
for(int j=1;j<=tn;++j)
cost[i][j]=min(cost[i][j],cost[i][k]+cost[k][j]);
}
void solve(){
int cas=(1<<n)-1;
for(int i=0;i<=cas;++i)
for(int j=0;j<n;++j)
dp[i][j]=-INF;
for(int i=0;i<n;++i)
if(money>=cost[1][t[i].in]+t[i].d)
dp[1<<i][i]=money-cost[1][t[i].in]-t[i].d+t[i].c;
for(int i=1;i<=cas;++i)
for(int j=0;j<n;++j){
if(dp[i][j]==-INF||!(i&(1<<j)))continue;
for(int k=0;k<n;++k){
if(j==k)continue;
int c=cost[t[j].in][t[k].in]+t[k].d;
if(!(i&(1<<k))&&dp[i][j]>=c){
int tot=dp[i][j]-c+t[k].c;
dp[i|(1<<k)][k]=max(dp[i|(1<<k)][k],tot);
}
}
}
int f=0;
for(int i=0;i<n;++i)
if(dp[cas][i]>=cost[1][t[i].in]){
// cout<<dp[cas][i]<<endl;
f=1;
break;
}
if(f)printf("YES\n");
else printf("NO\n");
}
int main()
{
int te;
scanf("%d",&te);
while(te--){
scanf("%d%d%d",&tn,&m,&money);
for(int i=0;i<=tn;++i)
for(int j=0;j<=tn;++j)
{
if(i==j)cost[i][j]=0;
else cost[i][j]=INF;
}
int u,v,c;
for(int i=0;i<m;++i){
scanf("%d%d%d",&u,&v,&c);
cost[u][v]=cost[v][u]=min(cost[u][v],c);
}
floyd();
scanf("%d",&n);
for(int i=0;i<n;++i)
scanf("%d%d%d",&t[i].in,&t[i].c,&t[i].d);
solve();
}
return 0;
}
Travel(HDU 4284状压dp)的更多相关文章
- HDU 4284 状压dp+spfa
题意: 给定n个点 m条无向边 d元. 以下m行表示每条边 u<=>v 以及花费 w 以下top 以下top行 num c d 表示点标为num的城市 工资为c 健康证价格为d 目标是经过 ...
- hdu 4284(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4284 思路:类似于poj3311:http://poj.org/problem?id=3311,首先f ...
- HDU 4778 状压DP
一看就是状压,由于是类似博弈的游戏.游戏里的两人都是绝对聪明,那么先手的选择是能够确定最终局面的. 实际上是枚举最终局面情况,0代表是被Bob拿走的,1为Alice拿走的,当时Alice拿走且满足变换 ...
- HDU - 4284 Travel(floyd+状压dp)
Travel PP loves travel. Her dream is to travel around country A which consists of N cities and M roa ...
- HDU 3001 状压DP
有道状压题用了搜索被队友骂还能不能好好训练了,, hdu 3001 经典的状压dp 大概题意..有n个城市 m个道路 成了一个有向图.n<=10: 然后这个人想去旅行.有个超人开始可以把他扔到 ...
- hdu 2809(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2809 思路:简单的状压dp,看代码会更明白. #include<iostream> #in ...
- hdu 2167(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2167 思路:经典的状压dp题,前后,上下,对角8个位置不能取,状态压缩枚举即可所有情况,递推关系是为d ...
- Engineer Assignment HDU - 6006 状压dp
http://acm.split.hdu.edu.cn/showproblem.php?pid=6006 比赛的时候写了一个暴力,存暴力,过了,还46ms 那个暴力的思路是,预处理can[i][j]表 ...
- hdu 3254 (状压DP) Corn Fields
poj 3254 n乘m的矩阵,1表示这块区域可以放牛,0,表示不能,而且不能在相邻的(包括上下相邻)两个区域放牛,问有多少种放牛的方法,全部不放也是一种方法. 对于每块可以放牛的区域,有放或者不放两 ...
随机推荐
- 在工程中添加pch文件
在Xcode6之前,新建一个工程的时候,系统会帮我们自动新建一个以工程名为名字的pch (precompile header)文件,在开发过程中,可以将那些整个工程都广泛使用的头文件包含在该文件下,编 ...
- [转]popwindow用法
[转]弹出窗口的两种实现方式 PopupWindow 和 Activity 链接:http://www.cnblogs.com/winxiang/archive/2012/11/20/2778729 ...
- 这是我用Microsoft Word 2010 直接发布的测试用博客
目的:如题所示. 那么先试试拷贝一段网页内容,发布后观察各种格式的显示效果如何. 下面的文字来自中国网新闻,地址是http://news.china.com.cn/2015-10/23/conte ...
- hdu 1213
简单并查集 #include <cstdio> #include <cstring> #define maxn 30005 int fa[maxn],ans[maxn],n,m ...
- uva 437 hdu 1069
dp 将石块按三个面存入队列 按底面积排序 dp就最大高度 按嵌套矩形最长路做做法 #include <iostream> #include <cstdio> #inc ...
- spoj 24
大数 #include<cstdio> #include<cstdlib> #include<cstring> #include<algorithm> ...
- POJ2524+并查集
题意简单. 询问n个人的宗教关系. #include<stdio.h> ; int fa[ maxn ]; int vis[ maxn ]; void init( int n ){ ;i& ...
- [数论]ZOJ3593 One Person Game
题意:一个人要从A走到B 只能走a布.b步.(a+b)步,可以往左或右走 问 最少要走几步,不能走到的输出-1 可以列出方程 $ax+by=A-B$ 或者 $ax+(a+b)y=A-B$ 或者 ...
- 在其他的电脑上配置绿色Jre+tomcat运行环境
其他的同事要使用我们的web程序(基于tomcat的web程序).所以要求是对方的电脑任何程序都不需要安装,把我们的包拷贝过去,直接执行批处理就可以运行. 经过了一番摸索,实现方式如下: 1,准备jr ...
- QT小技巧(书上没有的)
1. Layout本身不能控制隐藏和显示,但是可以在外面专门套一个Widget,然后控制这个Widget就可以达到相应的效果了. 2. 空目录居然也存在 if (QDir(""). ...