题意:给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)的更多相关文章

  1. HDU 4284 状压dp+spfa

    题意: 给定n个点 m条无向边 d元. 以下m行表示每条边 u<=>v 以及花费 w 以下top 以下top行 num c d 表示点标为num的城市 工资为c 健康证价格为d 目标是经过 ...

  2. hdu 4284(状压dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4284 思路:类似于poj3311:http://poj.org/problem?id=3311,首先f ...

  3. HDU 4778 状压DP

    一看就是状压,由于是类似博弈的游戏.游戏里的两人都是绝对聪明,那么先手的选择是能够确定最终局面的. 实际上是枚举最终局面情况,0代表是被Bob拿走的,1为Alice拿走的,当时Alice拿走且满足变换 ...

  4. 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 ...

  5. HDU 3001 状压DP

    有道状压题用了搜索被队友骂还能不能好好训练了,, hdu 3001 经典的状压dp 大概题意..有n个城市 m个道路  成了一个有向图.n<=10: 然后这个人想去旅行.有个超人开始可以把他扔到 ...

  6. hdu 2809(状压dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2809 思路:简单的状压dp,看代码会更明白. #include<iostream> #in ...

  7. hdu 2167(状压dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2167 思路:经典的状压dp题,前后,上下,对角8个位置不能取,状态压缩枚举即可所有情况,递推关系是为d ...

  8. Engineer Assignment HDU - 6006 状压dp

    http://acm.split.hdu.edu.cn/showproblem.php?pid=6006 比赛的时候写了一个暴力,存暴力,过了,还46ms 那个暴力的思路是,预处理can[i][j]表 ...

  9. hdu 3254 (状压DP) Corn Fields

    poj 3254 n乘m的矩阵,1表示这块区域可以放牛,0,表示不能,而且不能在相邻的(包括上下相邻)两个区域放牛,问有多少种放牛的方法,全部不放也是一种方法. 对于每块可以放牛的区域,有放或者不放两 ...

随机推荐

  1. 格式化说明符定义、转义字符、枚举、结构体、typedef

    1.格式化说明符定义: %i,%d:输出十进制整型数 %6d:输出十进制整型数,至少6个字符宽 %li,%ld:输出长整数 %u:输出无符号整数 %lu:输出无符号长整数(相当于:unsigned l ...

  2. 操作邮箱的类和文件的Md5【粘】

     MailMessage mailMsg = new MailMessage();//两个类,别混了,要引入System.Net这个Assembly             mailMsg.From ...

  3. I/O 流---输出流

    输出流(写入数据) a. 字节输出流 OutputStram 输出流的父类 FileOutputStream:  继承OutputStream 方法: OutputStream os=new File ...

  4. 基于Vuforia的Hololens图像识别

    微软官方Hololens开发文档中有关于Vuforia的内容,https://developer.microsoft.com/en-us/windows/holographic/getting_sta ...

  5. 对.net orm工具Dapper在多数据库方面的优化

    Dapper是近2年异军突起的新ORM工具,它有ado.net般的高性能又有反射映射实体的灵活性,非常适合喜欢原生sql的程序员使用,而且它源码很小,十分轻便.我写本博客的目的不是为了介绍Dapper ...

  6. 你想建设一个能承受500万PV/每天的网站吗?服务器每秒要处理多少个请求才能应对?

    你想建设一个能承受500万PV/每天的网站吗?服务器每秒要处理多少个请求才能应对? 你想建设一个能承受500万PV/每天的网站吗? 500万PV是什么概念?服务器每秒要处理多少个请求才能应对?如果计算 ...

  7. springMVC上传图片

    http://blog.csdn.net/cheung1021/article/details/7084673/ http://toutiao.com/a6293854906445021442/ 工程 ...

  8. [Ruby on Rails系列]3、初试Rails:使用Rails开发第一个Web程序

    本系列前两部分已经介绍了如何配置Ruby on Rails开发环境,现在终于进入正题啦! Part1.开发前的准备 本次的主要任务是开发第一个Rails程序.需要特别指出的是,本次我选用了一个(Paa ...

  9. Android 文字链接 文字点击时的背景颜色

    案例:实现“忘记密码?”这个链接,并且在按下的时候改变颜色. 方法一:这个可以用TextView实现: 主界面main.xml: <?xml version="1.0" en ...

  10. linux xxd 命令

    http://www.cnblogs.com/openix/archive/2012/04/23/2466320.html xxd -i dht.jpg dht.h