首先,对图进行一次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 送外卖的更多相关文章

  1. [codevs 2800]送外卖

    题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户分别在1~n个编号的城市中.送外卖的从0号城市出发,然后n个城市都要走一 ...

  2. codevs2800 送外卖

    题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户分别在1~n个编号的城市中.送外卖的从0号城市出发,然后n个城市都要走一 ...

  3. 【CodeVS2800】 送外卖 最短路+状压DP

    首先求出各点之间的最短路,floyed即可,注意是0-n. 然后考虑状压,f[i][j]表示状态为i时访问j点时的最短路和,1表示访问,0表示未访问,然后第j个点所在的位置就是(1<<j) ...

  4. 【wikioi】2800 送外卖(状压dp+floyd)

    http://www.wikioi.com/problem/2800/ 本题状压莫名其妙的tle了,(按照hzwer大神打的喂,他1000多ms,我就2000ms了?) (14.8.7更,将getnu ...

  5. 从送外卖到建站售主机还有共享自行车说起-2017年8月江西IDC排行榜与发展报告

    曾几何时,送外卖,这样的"低技术含量"工作,很难被互联网公司看上,直到百度将其当作连接终端用户与大数据的管道. 同样,销售主机域名和建站业务,本也是"微小体量" ...

  6. 2800 送外卖[状态压缩dp]

    2800 送外卖  时间限制: 2 s  空间限制: 256000 KB  题目等级 : 钻石 Diamond 题解       题目描述 Description 有一个送外卖的,他手上有n份订单,他 ...

  7. codevs 2800 送外卖 TSP问题

    2800 送外卖 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond         题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份 ...

  8. 送外卖(codevs 2800)

    题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户分别在1~n个编号的城市中.送外卖的从0号城市出发,然后n个城市都要走一 ...

  9. CODEVS_2800 送外卖 状态压缩+动态规划

    原题链接:http://codevs.cn/problem/2800/ 题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户 ...

随机推荐

  1. JS 实现关闭浏览器

        $('#exitSystem').on('click',function(){ if(confirm("确定要退出系统并关闭浏览器吗?")){ //关闭浏览器的方法只适用i ...

  2. VoIP常见编码的带宽计算

    voip带宽计算VOIP计算方法与所选用的编码方法有关,而与哪个厂家的没有什么关系,公式如下: 带宽=包长度×每秒包数=包长度×(1/打包周期)=(Ethernet头+IP头+UDP头+RTP头+有效 ...

  3. Cassandra 的启动和初始化

    Cassandra常用命令 Cassandra启动过程详解[原创] Cassandra 的入口 CassandraDaemon 作为Cassandra的入口,做了以下几件事: load configu ...

  4. 05:Sysbench压测-innodb_deadlock_detect参数对性能的影响

    目录 sysbench压测-innodb_deadlock_detect参数对性能的影响 一.OLTP测试前准备 二.进行OLTP测试 三.测试结果解读: 四.关于测试后的结论: 五.关于测试后的性能 ...

  5. 用CSS绘制最常见的40种形状和图形

    今天在国外的网站上看到了很多看似简单却又非常强大的纯CSS绘制的图形,里面有最简单的矩形.圆形和三角形,也有各种常见的多边形,甚至是阴阳太极和网站小图标,真的非常强大,分享给大家. Square(正方 ...

  6. js中Number()、parseInt()和parseFloat()的区别

    一:Number() 如果是Boolean值,true和false值将分别被转换为1和0. 如果是数字值,只是简单的传入和返回. 如果是null值,返回0. 如果是undefined,返回NaN. 如 ...

  7. 通过Java代码装配Bean

    上面梳理了通过注解来隐式的完成了组件的扫描和自动装配,下面来学习下如何通过显式的配置的装配bean 二.通过Java类装配bean 在前面定义了HelloWorldConfig类,并使用@Compon ...

  8. java byte to hex

    String str; byte[] bs = null; bs =str.getBytes(); bs =str.getBytes("utf-8") java  byte to ...

  9. mybatis 传入集合参数遍历 查询总结

    出自:http://blog.csdn.net/u013628152/article/details/51184641 1. findByIds(List ids) 如果参数的类型是List, 则在使 ...

  10. 用letsencrypt搭建免费的https网站--nginx篇

    环境:阿里云服务器centos7.3,nignx,letsencrypt做免费的https证书 Let’s Encrypt官网:https://letsencrypt.org/ 1.服务器开放端口:4 ...