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,表示不能,而且不能在相邻的(包括上下相邻)两个区域放牛,问有多少种放牛的方法,全部不放也是一种方法. 对于每块可以放牛的区域,有放或者不放两 ...
随机推荐
- 各个浏览器下实现Ajax的JS
var xmlhttpget; try { // Firefox, Opera 8.0+, Safari xmlhttpget = new window.XMLHttpRequest( ...
- 扎克伯格谈Facebook创业过程
第一课:Facebook的产品研发 (1)不仅注重用户体验,更关注程序本身对社会和产品的是否有益,进而对产品做出调整 (2)以学校为标准作为群组来划分,就是对产品进行了思考后决定的,不管是直觉决定还是 ...
- 免费素材:25套免费的 Web UI 设计的界面元素(转)
Web 元素是任何网站相关项目都需要的,质量和良好设计的元素对于设计师来说就像宝贝一样.如果您正在为您的网站,博客,Web 应用程序或移动应用程序寻找完美设计的网页元素,那么下面这个列表会是你需要的. ...
- 看几道JQuery试题后总结(下篇)
感谢圆友的提醒 昨天下午完成了9道试题中的前4道,之后好多园友存在些疑惑和建议,在这里我一并说一下吧.首先对于昨天第一题可能存在误导,在JQuery中并没有innerHTML这个属性,不过我们可以将J ...
- live555源码研究(三)------UsageEnvironment类
一.UsageEnvironment类作用 1,不使用的时候回收当前的使用环境. 2,对返回结果消息和错误消息的维护. 二.类UsageEnvironment继承关系图
- JavaWeb学习总结(四十八)——模拟Servlet3.0使用注解的方式配置Servlet
一.Servlet的传统配置方式 在JavaWeb开发中, 每次编写一个Servlet都需要在web.xml文件中进行配置,如下所示: 1 <servlet> 2 <servlet- ...
- Web开发的绝美网站
http://paranimage.com/ http://sixrevisions.com/graphics-design/
- SRM588
250: 有n首歌每首歌有duration和tone,连续唱m首歌会消耗每首歌的duration以及相邻两首歌的tone的差的绝对值的和,给个T,问说在T时间内最对能唱多少歌. 将歌按tone排序后发 ...
- POJ2586——Y2K Accounting Bug
Y2K Accounting Bug Description Accounting for Computer Machinists (ACM) has sufferred from the Y2K ...
- nigix以及相关
nginx+php的配置 php与nginx整合 http://www.thinkphp.cn/topic/13082.html [入门篇]Nginx + FastCGI 程序(C/C++) 搭建高性 ...