洛谷P1171 售货员的难题
P1171 售货员的难题
题目背景
数据有更改
题目描述
某乡有n个村庄(1<n<20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)是已知的,且A村到B村与B村到A村的路大多不同。为了提高效率,他从商店出发到每个村庄一次,然后返回商店所在的村,假设商店所在的村庄为1,他不知道选择什么样的路线才能使所走的路程最短。请你帮他选择一条最短的路。
输入输出格式
输入格式:
村庄数n和各村之间的路程(均是整数)。
输出格式:
最短的路程。
输入输出样例
说明
输入解释
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 售货员的难题的更多相关文章
- 洛谷 P1171 售货员的难题
P1171 售货员的难题 题目背景 数据有更改 题目描述 某乡有n个村庄(1<n<20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)是已知的,且 ...
- 洛谷 P1171 售货员的难题 【状压dp】
题目描述 某乡有n个村庄(1<n<20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)是已知的,且A村到B村与B村到A村的路大多不同.为了提高效率 ...
- 洛谷P1171 售货员的难题【状压DP】
题目描述 某乡有n个村庄(1 输入格式: 村庄数n和各村之间的路程(均是整数). 输出格式: 最短的路程. 输入样例: 3 0 2 1 1 0 2 2 1 0 输出样例 3 说明 输入解释 3 {村庄 ...
- 2018.07.18 洛谷P1171 售货员的难题(状压dp)
传送门 感觉是一道经典的状压dp,随便写了一发卡了卡常数开了个O(2)" role="presentation" style="position: relati ...
- P1171 售货员的难题
P1171 售货员的难题 题目描述 某乡有nn个村庄(1<n \le 201<n≤20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)s(0< ...
- 洛谷 P1379 八数码难题 Label:判重&&bfs
特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...
- 【题解】P1171 售货员的难题
Tags 搜索,状压. 裸的旅行商问题 #include <stdio.h> #include <string.h> #define re register #define ...
- P1171 售货员的难题--搜索(剪枝)
题目背景 数据有更改 题目描述 某乡有nn个村庄(1<n \le 201<n≤20),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0<s<1000)s(0<s ...
- 洛谷P1379八数码难题
题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中. 要求解的问题是:给出一种初始布局(初始状态)和目标布局(为 ...
随机推荐
- Poj 1659 Distance on Chessboard(国际象棋的走子规则)
一.Description 国际象棋的棋盘是黑白相间的8 * 8的方格,棋子放在格子中间.如下图所示: 王.后.车.象的走子规则如下: 王:横.直.斜都可以走,但每步限走一格. 后:横.直.斜都可以走 ...
- IAR常用快捷键及技巧
1.复制和粘贴几行的部分代码 需求:有时候我们需要复制几行代码的后半部分,不需要复制前半部分.方法:按住Alt键,再用鼠标拖动就可以复制和粘贴后半部分 [END/2015-09-23] 2.复制一行 ...
- Python:内置函数zip()
zip函数接受任意多个可迭代对象作为参数,将对象中对应的元素打包成一个tuple,然后返回一个可迭代的zip对象. 这个可迭代对象可以使用循环的方式列出其元素 若多个可迭代对象的长度不一致,则所返回的 ...
- Python:列表反序和解析
1)列表反序 A.list.reverse():将列表反序: l = [1, 2, 3, 4, 5] print(l.reverse()) -->[5, 4, 3, 2, 1] B.l.[::- ...
- JVM插庄之一:JVM字节码增强技术介绍及入门示例
字节码增强技术:AOP技术其实就是字节码增强技术,JVM提供的动态代理追根究底也是字节码增强技术. 目的:在Java字节码生成之后,对其进行修改,增强其功能,这种方式相当于对应用程序的二进制文件进行修 ...
- 事务之五:Spring @Transactional工作原理
本文将深入研究Spring的事务管理.主要介绍@Transactional在底层是如何工作的. JPA(Java Persistence API--java持久层)和事务管理 很重要的一点是JPA本身 ...
- 7.JasperReports学习笔记7-applet打印
转自:http://www.blogjava.net/vjame/archive/2013/10/12/404908.html 打包applet的class和所需的jar包,并加上数字签名 要运行打印 ...
- k8s 基础 k8s架构和组件
k8s 的总架构图
- tomcat solr 限制ip
<Context path="/solr" reloadable="false" docBase="/var/www"> < ...
- linux 安装输入法
简述 Ubuntu16.04安装完后,和12.04以及14.04都不一样,并没有中文输入功能.于是搜索一些安装中文输入法的方法. 开始安装了ibus pinyin输入法,但是系统重启之后发现有些时候不 ...