code2800 送外卖
首先,对图进行一次Floyd(g[][]是图)
1.dfs:(u是当前在的节点,d是已经走的路程)
void dfs(int u,int d){
if(d>=ans)return; bool flag=false;
for(int i=;i<=n;i++){
if(vis[i]==false&&i!=u){
flag=true;
vis[i]=true;
dfs(i,d+g[u][i]);
vis[i]=false;
}
}
if(flag==false){
d+=g[u][];
if(ans>d)ans=d; }
}
起初我认为n<=15是dfs完全可以解决的,但是忽略了一个问题:每对城市之间都可以互相到达,边特别多,结果TLE ^_^;
正解是压缩状态的dp:
dp[u][s]表示状态:走到u这个点并且前面已经走完了集合s中的点 的最短距离
s是二进制压缩状态 1到过 0没有
ps:u这个点本身也包括在集合s中
s0是把s中u去掉后的集合 s0 = s & ((1<<n)-1 - (1<<(u-1)) ) //@_@a...
dp[u][s]=min{ dp[i][s0]+g[i][u] }
i是集合s0中包含的点,注意是 +g[i][u],因为是先走到i,再从i到u(题目中说城市a到城市b的时间和城市b到城市a的时间不一定相同)
代码如下:
#include<iostream>
#include <bitset>
#include<cstring>
using namespace std; int n;
int g[][];
int dp[][<<];
bool vis[][<<]; void Floyd(){
for(int k=;k<=n;k++){
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
if(i==k||j==k||i==j)continue;
g[i][j]=min(g[i][j], g[i][k]+g[k][j]);
}
}
}
} /*void dfs(int u,int d){
if(d>=ans)return; bool flag=false;
for(int i=1;i<=n;i++){
if(vis[i]==false&&i!=u){
flag=true;
vis[i]=true;
dfs(i,d+g[u][i]);
vis[i]=false;
}
}
if(flag==false){
d+=g[u][0];
if(ans>d)ans=d; }
}*/ int dfs(int u,int s){
if(vis[u][s])return dp[u][s];
vis[u][s]=true; int s0= s & ((<<n)- - (<<(u-)) );
//cout<<u<<" "<<bitset<sizeof(int)*8>(s)<<" "<<bitset<sizeof(int)*8>(s0)<<endl;
int cnt=;
int& ans=dp[u][s];
for(int i=;i<=;i++){
if(s0&(<<(i-))){
cnt++;
int x=dfs(i, s0)+g[i][u];
ans=min(ans,x);
}
}
if(cnt==){
ans=g[][u];
}
return ans;
} int main(){
//freopen("2800.txt","r",stdin);
memset(dp,0x3f,sizeof(dp));
memset(vis,false,sizeof(vis)); cin>>n;
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
cin>>g[i][j];
}
} Floyd();
/*for(int i=0;i<=n;i++){
for(int j=0;j<=n;j++){
cout<<g[i][j]<<' ';
}
cout<<endl;
}*/ cout<<dfs(,(<<n)-)<<endl; /*int a,b;
while(cin>>a>>b){
cout<<dp[a][b]<<endl;
}*/
//fclose(stdin);
return ;
}
ps:你看到了大量的注释,它们包括深搜算法和Debug(我懒得删去了^_^!)
ps:文字表情太帅了! 来一个最经典的 :)
code2800 送外卖的更多相关文章
- [codevs 2800]送外卖
题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户分别在1~n个编号的城市中.送外卖的从0号城市出发,然后n个城市都要走一 ...
- codevs2800 送外卖
题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户分别在1~n个编号的城市中.送外卖的从0号城市出发,然后n个城市都要走一 ...
- 【CodeVS2800】 送外卖 最短路+状压DP
首先求出各点之间的最短路,floyed即可,注意是0-n. 然后考虑状压,f[i][j]表示状态为i时访问j点时的最短路和,1表示访问,0表示未访问,然后第j个点所在的位置就是(1<<j) ...
- 【wikioi】2800 送外卖(状压dp+floyd)
http://www.wikioi.com/problem/2800/ 本题状压莫名其妙的tle了,(按照hzwer大神打的喂,他1000多ms,我就2000ms了?) (14.8.7更,将getnu ...
- 从送外卖到建站售主机还有共享自行车说起-2017年8月江西IDC排行榜与发展报告
曾几何时,送外卖,这样的"低技术含量"工作,很难被互联网公司看上,直到百度将其当作连接终端用户与大数据的管道. 同样,销售主机域名和建站业务,本也是"微小体量" ...
- 2800 送外卖[状态压缩dp]
2800 送外卖 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 有一个送外卖的,他手上有n份订单,他 ...
- codevs 2800 送外卖 TSP问题
2800 送外卖 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份 ...
- 送外卖(codevs 2800)
题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户分别在1~n个编号的城市中.送外卖的从0号城市出发,然后n个城市都要走一 ...
- CODEVS_2800 送外卖 状态压缩+动态规划
原题链接:http://codevs.cn/problem/2800/ 题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户 ...
随机推荐
- JS 实现关闭浏览器
$('#exitSystem').on('click',function(){ if(confirm("确定要退出系统并关闭浏览器吗?")){ //关闭浏览器的方法只适用i ...
- VoIP常见编码的带宽计算
voip带宽计算VOIP计算方法与所选用的编码方法有关,而与哪个厂家的没有什么关系,公式如下: 带宽=包长度×每秒包数=包长度×(1/打包周期)=(Ethernet头+IP头+UDP头+RTP头+有效 ...
- Cassandra 的启动和初始化
Cassandra常用命令 Cassandra启动过程详解[原创] Cassandra 的入口 CassandraDaemon 作为Cassandra的入口,做了以下几件事: load configu ...
- 05:Sysbench压测-innodb_deadlock_detect参数对性能的影响
目录 sysbench压测-innodb_deadlock_detect参数对性能的影响 一.OLTP测试前准备 二.进行OLTP测试 三.测试结果解读: 四.关于测试后的结论: 五.关于测试后的性能 ...
- 用CSS绘制最常见的40种形状和图形
今天在国外的网站上看到了很多看似简单却又非常强大的纯CSS绘制的图形,里面有最简单的矩形.圆形和三角形,也有各种常见的多边形,甚至是阴阳太极和网站小图标,真的非常强大,分享给大家. Square(正方 ...
- js中Number()、parseInt()和parseFloat()的区别
一:Number() 如果是Boolean值,true和false值将分别被转换为1和0. 如果是数字值,只是简单的传入和返回. 如果是null值,返回0. 如果是undefined,返回NaN. 如 ...
- 通过Java代码装配Bean
上面梳理了通过注解来隐式的完成了组件的扫描和自动装配,下面来学习下如何通过显式的配置的装配bean 二.通过Java类装配bean 在前面定义了HelloWorldConfig类,并使用@Compon ...
- java byte to hex
String str; byte[] bs = null; bs =str.getBytes(); bs =str.getBytes("utf-8") java byte to ...
- mybatis 传入集合参数遍历 查询总结
出自:http://blog.csdn.net/u013628152/article/details/51184641 1. findByIds(List ids) 如果参数的类型是List, 则在使 ...
- 用letsencrypt搭建免费的https网站--nginx篇
环境:阿里云服务器centos7.3,nignx,letsencrypt做免费的https证书 Let’s Encrypt官网:https://letsencrypt.org/ 1.服务器开放端口:4 ...