哭瞎啊,每一个城市能够经过至多两次,但没有要求必须经过两次。想用 两个状压来乱搞搞。结果自觉得会T。结果 WA了,搞了一下午。没想到用三进制啊。智商捉急,參考了

http://blog.csdn.net/lenleaves/article/details/7980955  这个博客

每一个城市能够经过1或2次。所以三进制能够代表全部状态了。接下来处理方式类似于二进制的,仅仅是没有了位运算一些推断跟预处理有点繁琐

方程dp[s][i] = min(dp[s][i] ,  dp[s - (s除去j剩下状态)][k] + dis[k][j]),

因为没有固定的出发点,所以也就没有固定的终点。所以要以不论什么城市为终点的可能都要枚举到

dp[i][j]代表i状态下以 j为终点的最小花费

转移方程就是  : i  状态以j为终点的递推为(i状态中不经过j位置的状态下以k为终点 + k到j所需距离).

#define MAXN 0x3f3f3f3f

int n,m;

int dp[100000 + 55][10 + 5];

int mp[10 + 5][10 + 5];

int s[59050][10 + 5];

void clear() {

	for(int i=0;i<59050;i++) {
int tmp = i;
for(int j=1;j<=10;j++) {
s[i][j] = tmp%3;
tmp /= 3;
if(!tmp)break;
}
}
} void init() {
memset(mp,0x3f3f3f3f,sizeof(mp));
memset(dp,0x3f3f3f3f,sizeof(dp));
} bool input() {
while(scanf("%d %d",&n,&m) == 2) {
for(int i=0;i<m;i++) {
int u,v,val;
scanf("%d %d %d",&u,&v,&val);
if(val < mp[u][v]) {
mp[u][v] = val;
mp[v][u] = val;
}
}
return false;
}
return true;
} void cal() {
if(n == 1) {puts("0");return ;}
int now[12];
now[0] = 0;
now[1] = 1;
for(int i=2;i<=11;i++)now[i] = 3 * now[i - 1];/*举出刚好仅仅过i位置的状态*/
for(int i=0;i<=n;i++)dp[now[i]][i] = 0;//边界值。仅仅经过i位置的状态再以i为终点耗费肯定为0
int ans = MAXN;
for(int i=0;i<now[n + 1];i++) {
bool flag = true;//标记推断是否訪问了全部的地方
for(int j=1;j<=n;j++) {/*枚举以j为终点*/
if(s[i][j] == 0) {flag = false;continue;}//i状态并没有经过j
for(int k=1;k<=n;k++) {
if(s[i][k] == 0)continue;/*i状态没有经过k*/
int tmp = i - now[j];//使得i状态中第j位置为0
dp[i][j] = min(dp[i][j],dp[tmp][k] + mp[k][j]);
/*i状态以j为终点的递推为(i状态中只是j位置的状态下以k为终点 + k到j所需距离)*/
}
}
if(flag)//若该状态下全部地方都訪问过了,就从以各个地方为终点的最佳方案中再取出最优的
for(int j=1;j<=n;j++)ans = min(ans,dp[i][j]);
}
if(ans == MAXN)puts("-1");
else printf("%d\n",ans);
} void output() { } int main () {
clear();
while(true) {
init();
if(input())return 0;
cal();
output();
}
return 0;
}

HDU3001 Travelling 状压DP的更多相关文章

  1. HDU3001 Travelling —— 状压DP(三进制)

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=3001 Travelling Time Limit: 6000/3000 MS (Java/ ...

  2. HDU 3001 Travelling ——状压DP

    [题目分析] 赤裸裸的状压DP. 每个点可以经过两次,问经过所有点的最短路径. 然后写了一发四进制(真是好写) 然后就MLE了. 懒得写hash了. 改成三进制,顺利A掉,时间垫底. [代码] #in ...

  3. hdu3001(状压dp)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=3001 题意:n 个城市已经 m 条路 以及对应路费 c,要求遍历所有城市最少的路费,每个城市不能超过2 ...

  4. hdu3001(状压dp,三进制)

    Travelling Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  5. HDU - 3001 Travelling 状压dp + 三进制 [kuangbin带你飞]专题二

    终于刷完搜索专题了. 题意:给定n个城市,每个城市参观不能超过两次,两个城市之间有道路通过需要花费X,求通过能所有城市的最小花费. 思路:每个城市有三个状态0,1,2,可用三进制存储所有城市的访问状态 ...

  6. HDU 3001 Travelling (状压DP + BFS)

    题意:有一个人要去旅游,他想要逛遍所有的城市,但是同一个城市又不想逛超过2次.现在给出城市之间的来往路费,他可以选择任意一个点为起点. 问逛遍所有城市的最低路费是多少. 析:用三进制表示每个城市的访问 ...

  7. Travelling(HDU3001+状压dp+三进制+最短路)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3001 题目: 题意:n个城市,m条边,每条边都有一个权值,问你经过所有的城市且每条边通过次数不超过两次 ...

  8. hdu 3001 Travelling 经过所有点(最多两次)的最短路径 三进制状压dp

    题目链接 题意 给定一个\(N\)个点的无向图,求从任意一个点出发,经过所有点的最短路径长度(每个点至多可以经过两次). 思路 状态表示.转移及大体思路 与 poj 3311 Hie with the ...

  9. HDU 3001 Travelling (状压DP,3进制)

    题意: 给出n<=10个点,有m条边的无向图.问:可以从任意点出发,至多经过同一个点2次,遍历所有点的最小费用? 思路: 本题就是要卡你的内存,由于至多可经过同一个点2次,所以只能用3进制来表示 ...

随机推荐

  1. Leetcode 之Largest Rectangle in Histogram(40)

    又是一道构思巧妙的题,暴力求解复杂度太高,通过构造一个递增栈来解决:如果当前元素小于栈顶元素,则说明栈内已经构成一个 递增栈,则分别计算以每个元素为最低值的面积:反之,则入栈. int largest ...

  2. SPOJ Two Paths

    Description 给定一个无向图,含有一定的路.从中找出两个最长的路径(每条路径有一些相通路组成)这两个路径不能经过公共的点,求何时二路径的乘积最大. 本题给出的无向图是一棵树,每边权值为1. ...

  3. hdu 1829(继续扩展并查集)

    A Bug's Life Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tot ...

  4. Go语言基础单元测试示例

    这个要熟悉原理,要能写.. 但现在..... 注意,没有main函数,以_test.go结尾,命令go test -v package main import ( "testing" ...

  5. JMX monitor weblogic 总结

    https://blog.csdn.net/joy_91/article/details/42774839

  6. Linux:hping高级主机扫描

    https://www.aliyun.com/jiaocheng/167107.html https://blog.csdn.net/weixin_39762926/article/details/7 ...

  7. Linux文件系统中/tmp的临时文件清理说明

    https://www.cnblogs.com/MonkeyAC/articles/3631401.html

  8. Ionic-wechat项目边开发边学(一):环境搭建和创建一个项目

    之前学AngularJS,教程过了一遍觉得很简单,但真正写几个Demo就错误百出,一个小小的功能要折腾很久.所以这次学Ionic,准备以开发一个项目为切入点去学,那么问题来了,开发什么项目呢? 纠结了 ...

  9. PTA L2-002 链表去重 团体程序设计天梯赛-练习集

    L2-002 链表去重(25 分)   给定一个带整数键值的链表 L,你需要把其中绝对值重复的键值结点删掉.即对每个键值 K,只有第一个绝对值等于 K 的结点被保留.同时,所有被删除的结点须被保存在另 ...

  10. 洛谷P1414 又是毕业季 [数论]

    题目传送门 又是毕业季 题目背景 “叮铃铃铃”,随着高考最后一科结考铃声的敲响,三年青春时光顿时凝固于此刻.毕业的欣喜怎敌那离别的不舍,憧憬着未来仍毋忘逝去的歌.1000多个日夜的欢笑和泪水,全凝聚在 ...