P1171 售货员的难题

题目背景

数据有更改

题目描述

某乡有n个村庄(1<n<20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)是已知的,且A村到B村与B村到A村的路大多不同。为了提高效率,他从商店出发到每个村庄一次,然后返回商店所在的村,假设商店所在的村庄为1,他不知道选择什么样的路线才能使所走的路程最短。请你帮他选择一条最短的路。

输入输出格式

输入格式:

村庄数n和各村之间的路程(均是整数)。

输出格式:

最短的路程。

输入输出样例

输入样例#1: 复制

3
0 2 1
1 0 2
2 1 0
输出样例#1: 复制

3

说明

输入解释

3 {村庄数}

0 2 1 {村庄1到各村的路程}

1 0 2 {村庄2到各村的路程}

2 1 0 {村庄3到各村的路程}

/*
洛谷上只能到90分qwq
*/
#include<iostream>
#include<cstdio>
#define maxn 20
int n,num,head[maxn],ans=0x7fffffff;
struct node{
int to,pre,v;
}e[maxn*maxn];
bool vis[maxn];
using namespace std;
void Insert(int from,int to,int v){
e[++num].to=to;
e[num].v=v;
e[num].pre=head[from];
head[from]=num;
}
void dfs(int pos,int cnt,int dis){
if(dis>=ans)return;
if(dis+n-cnt+>=ans)return;
for(int i=head[pos];i;i=e[i].pre){
int to=e[i].to;
if(to==&&cnt==n){
ans=min(ans,dis+e[i].v);
return;
}
if(vis[to])continue;
vis[to]=;
dfs(to,cnt+,dis+e[i].v);
vis[to]=;
}
}
int qread(){
int i=;
char ch=getchar();
while(ch<''||ch>'')ch=getchar();
while(ch<=''&&ch>=''){i=i*+ch-'';ch=getchar();}
return i;
}
int main(){
freopen("Cola.txt","r",stdin);
n=qread();
int x;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++){
x=qread();
if(i!=j)Insert(i,j,x);
}
vis[]=;
dfs(,,);
printf("%d",ans);
}

90分 搜索+剪枝

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,map[][],all,dp[][<<],ans=0x7fffffff;
int qread(){
int i=;
char ch=getchar();
while(ch<''||ch>'')ch=getchar();
while(ch<=''&&ch>=''){i=i*+ch-'';ch=getchar();}
return i;
}
int main(){
freopen("Cola.txt","r",stdin);
//scanf("%d",&n);
n=qread();
all=(<<n)-;
for(int i=;i<=n;i++)for(int j=;j<=n;j++)map[i][j]=qread();
memset(dp,0x3f,sizeof(dp));
dp[][]=;
for(int i=;i<=n;i++)dp[i][<<(i-)]=map[][i];
for(int s=;s<=all;s++){
for(int i=;i<=n;i++)
if(s&(<<(i-)))
for(int j=;j<=n;j++)
dp[i][s]=min(dp[i][s],dp[j][s^(<<(i-))]+map[j][i]);
}
for(int i=;i<=n;i++)ans=min(ans,dp[i][all]+map[i][]);
printf("%d",ans);
}

80分 状压+枚举

#include<iostream>
#include<cstdio>
#include<cstring>
#define min(a,b) (a)>(b)?(b):(a)
int n,map[][],all,dp[][<<],ans=0x7fffffff,bit[];
int qread(){
int i=;
char ch=getchar();
while(ch<''||ch>'')ch=getchar();
while(ch<=''&&ch>=''){i=i*+ch-'';ch=getchar();}
return i;
}
int main(){
freopen("Cola.txt","r",stdin);
//scanf("%d",&n);
bit[]=;
for(int i=;i<=;i++)bit[i]=bit[i-]<<;
n=qread();
all=(<<n)-;
for(int i=;i<=n;i++)for(int j=;j<=n;j++)map[i][j]=qread();
memset(dp,0x3f,sizeof(dp));
dp[][]=;
for(int s=;s<=all;s+=){
for(int i=;i<=n;i++)
if(dp[i][s]<=)
for(int j=;j<=n;j++)
if(!(s&bit[j]))
dp[j][s|bit[j]]=min(dp[j][s|bit[j]],dp[i][s]+map[i][j]);
}
for(int i=;i<=n;i++)ans=min(ans,dp[i][all]+map[i][]);
printf("%d",ans);
}

100分 状压

洛谷P1171 售货员的难题的更多相关文章

  1. 洛谷 P1171 售货员的难题

    P1171 售货员的难题 题目背景 数据有更改 题目描述 某乡有n个村庄(1<n<20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)是已知的,且 ...

  2. 洛谷 P1171 售货员的难题 【状压dp】

    题目描述 某乡有n个村庄(1<n<20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)是已知的,且A村到B村与B村到A村的路大多不同.为了提高效率 ...

  3. 洛谷P1171 售货员的难题【状压DP】

    题目描述 某乡有n个村庄(1 输入格式: 村庄数n和各村之间的路程(均是整数). 输出格式: 最短的路程. 输入样例: 3 0 2 1 1 0 2 2 1 0 输出样例 3 说明 输入解释 3 {村庄 ...

  4. 2018.07.18 洛谷P1171 售货员的难题(状压dp)

    传送门 感觉是一道经典的状压dp,随便写了一发卡了卡常数开了个O(2)" role="presentation" style="position: relati ...

  5. P1171 售货员的难题

    P1171 售货员的难题 题目描述 某乡有nn个村庄(1<n \le 201<n≤20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)s(0< ...

  6. 洛谷 P1379 八数码难题 Label:判重&&bfs

    特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...

  7. 【题解】P1171 售货员的难题

    Tags 搜索,状压​. 裸的旅行商问题 #include <stdio.h> #include <string.h> #define re register #define ...

  8. P1171 售货员的难题--搜索(剪枝)

    题目背景 数据有更改 题目描述 某乡有nn个村庄(1<n \le 201<n≤20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)s(0<s ...

  9. 洛谷P1379八数码难题

    题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中. 要求解的问题是:给出一种初始布局(初始状态)和目标布局(为 ...

随机推荐

  1. JS使用模板快速填充HTML控件数据

    function formatTemplate(dta, tmpl) { var format = { name: function(x) { return x ; } }; return tmpl. ...

  2. IO - 同步,异步,阻塞,非阻塞 (转帖:http://blog.csdn.net/historyasamirror/article/details/5778378)

    同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到底有什么区别?这个问题其实不同的人给出 ...

  3. windows中android SDK manager安装更新sdk很慢,或者出现Done loading packages后不动甚至没有任何可用包

    出现问题: 1.windows中android SDK manager安装更新sdk很慢,或者出现Done loading packages后不动甚至没有任何可用包 2.Failed to fetch ...

  4. 【leetcode刷题笔记】Plus One

    Given a non-negative number represented as an array of digits, plus one to the number. The digits ar ...

  5. xdebug浏览器调试参数

    XDEBUG_SESSION_START=phpstorm-xdebug 找到对应PHP版本的 Xdebug ,后面带 TS 的为线程安全,本机环境为 win7 64 + php-5.5.1-Win3 ...

  6. BZOJ2120:数颜色

    浅谈树状数组与线段树:https://www.cnblogs.com/AKMer/p/9946944.html 题目传送门:https://www.lydsy.com/JudgeOnline/prob ...

  7. 照片Urls

    http://img.my.csdn.net/uploads/201402/16/1392530364_7835.jpg http://img.my.csdn.net/uploads/201402/1 ...

  8. 使用swift命令遭遇503错误

    使用swift命令遭遇503 Internal Server Error.这个问题可能有很多种原因,这里只描述下我当前遇到的一种情况. 我们实验环境下的swift设有3个zone,有1个proxy n ...

  9. JWT(JSON WEB TOKEN) / oauth2 / SSL

    1: JWT: 为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准((RFC 7519).该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景.JWT的声明一般被 ...

  10. 【转】Jquery折叠效果

    转自:http://www.cnblogs.com/clc2008/archive/2011/10/25/2223254.html <!DOCTYPE html PUBLIC "-// ...