博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
lightoj 1057 - Collecting Gold(状压dp)
阅读量:5238 次
发布时间:2019-06-14

本文共 1698 字,大约阅读时间需要 5 分钟。

题目链接:

 

题解:看似有点下记忆话搜索但是由于他是能走8个方向的也就是说两点的距离其实就是最大的x轴或y轴的差。然后只有15个藏金点状压一下加dfs就行了。

#include 
#include
#include
#include
#define inf 0X3f3f3f3fusing namespace std;char mmp[30][30];struct TnT { int x , y;}Node[20];int getlen(int x , int y) { return max(abs(Node[x].x - Node[y].x) , abs(Node[x].y - Node[y].y));}int dp[17][1 << 17] , cnt;void dfs(int pos , int state) { if(state == (1 << cnt) - 1) return ; for(int i = 0 ; i < cnt ; i++) { if(state & (1 << i)) continue; else { if(dp[i][state | (1 << i)] > dp[pos][state] + getlen(pos , i)) { dp[i][state | (1 << i)] = dp[pos][state] + getlen(pos , i); dfs(i , state | (1 << i)); } } }}int main() { int t; scanf("%d" , &t); int n , m , Case = 0; while(t--) { scanf("%d%d" , &n , &m); int count = 0; for(int i = 0 ; i < n ; i++) { scanf("%s" , mmp[i]); for(int j = 0 ; j < m ; j++) { if(mmp[i][j] == 'x') Node[0].x = i , Node[0].y = j; if(mmp[i][j] == 'g') Node[++count].x = i , Node[count].y = j; } } for(int i = 0 ; i <= count ; i++) { for(int j = 0 ; j < (1 << count + 1) ; j++) { dp[i][j] = inf; } } cnt = count + 1; dp[0][0] = 0; dfs(0 , 0); int ans = inf; for(int i = 1 ; i <= count ; i++) { ans = min(ans , dp[i][(1 << cnt) - 1] + getlen(0 , i)); } printf("Case %d: %d\n" , ++Case , ans == inf ? 0 : ans); } return 0;}

转载于:https://www.cnblogs.com/TnT2333333/p/7134377.html

你可能感兴趣的文章
myeclipse对象输入“.”后不自动提示
查看>>
前端页面HTML 标签 CSS, JS总结
查看>>
poj 1160
查看>>
c语言-键盘扫描码
查看>>
折半查找、
查看>>
兼容IE的写法收集||bug修复
查看>>
9款极具创意的HTML5/CSS3进度条动画
查看>>
订阅号如何实现网页授权?
查看>>
【小程序】添加tabBar后navigateTo失效
查看>>
http 条件请求
查看>>
第13周学习进度
查看>>
Redis(一):centos下安装。
查看>>
UIImage图片处理,旋转、截取、平铺、缩放等操作
查看>>
分布式事务1
查看>>
用C++,调用浏览器打开一个网页
查看>>
(Greedy) leetcode 55. 45. Jump Game I II
查看>>
html第七节课
查看>>
ios 获取当前设备信息、内存
查看>>
ArcGIS API for JavaScript 入门教程[4] 代码的骨架
查看>>
try-catch和throw,throws的区别 (转)
查看>>