B - 下沙小面的(2)

Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d
& %I64u

Description

前文再续,书接上一题。话说当上小面的司机的Lele在施行他的那一套拉客法则以后,由于走的路线太长,油费又贵,不久便亏本了。(真可怜~)于是他又想了一个拉客的办法。 



对于每一次拉客活动,他一次性把乘客都拉上车(当然也不会超过7个,因为位置只有7个)。然后,Lele计算出一条路线(出于某些目的,Lele只把车上乘客的目的地作为这条路线上的站点),把所有乘客都送到目的地(在这路线上不拉上其他乘客),并且使总路线长度最短。 



不过Lele每次都要花很多时间来想路线,你能写个程序帮他嘛?

Input

本题目包含多组测试。最后一组测试后有一个0代表结束。 

每组测试第一行有一个整数NCity(3<=NCity<=30)表示下沙一共有多少个站点(站点从0开始标号)。 

然后给你一个 NCity * NCity 的矩阵,表示站点间的两两距离。即这个矩阵中第 i 行 第 j 列的元素表示站点 i 和站点 j 的距离。(0<=距离<=1000) 

再然后有一个整数K(1<=K<=7),表示Lele拉上车的人数。 

接下来的一行里包括 K 个整数,代表上车的人分别要去的站点。(0<站点<NCity) 



注意: 

对于每组测试,Lele都是在站点0拉上乘客的。

Output

对于每一组测试,在一行内输出一个整数,表示最短路线的长度。

Sample Input

3
0 1 2
1 0 3
2 3 0
3
1 1 2
0

Sample Output

4
#include<stdio.h>
#include<algorithm>
#include<string.h>
using namespace std;
int n,m,b[100],c[100],a[100],minlength;
int map[100][100];
void dfs(int step,int length,int last)
{
if(step==m)
{
minlength=min(length,minlength);
return;
}
else
{
for(int i=0; i<m; i++)
if(!b[i])
{
b[i]=1;
dfs(step+1,length+map[last][a[i]],a[i]);
b[i]=0;
}
}
}
int main()
{
while(~scanf("%d",&n),n)
{
int i,j;
memset(b,0,sizeof(b));
memset(c,0,sizeof(c));
for(i=0; i<n; i++)
for(j=0; j<n; j++)
scanf("%d",&map[i][j]);
scanf("%d",&m);
for(i=0; i<m; i++)
scanf("%d",&c[i]);
sort(c,c+m);//先排序在去重
for(j=i=0; i<m-1; i++)
if(c[i]!=c[i+1])
a[j++]=c[i];
a[j]=c[i];
m=j+1;
minlength=0x3f3f3f3f;//最大值
dfs(0,0,0);
printf("%d\n",minlength);
}
return 0;
} //#include<iostream>
//#include<queue>
//#include<stdio.h>
//#include<algorithm>
//using namespace std;
//int map[31][31],n;
//int main()
//{
// int i,j,m,sum,a[10],b[10],x;
// while(~scanf("%d",&n),n)
// {
// sum=999999;
// for(i=0; i<n; i++)
// for(j=0; j<n; j++)
// scanf("%d",&map[i][j]);
// scanf("%d",&m);
// for(i=0; i<m; i++)
// scanf("%d",&b[i]);
// sort(b,b+m);
// b[m]=-1;
// for(j=i=0; i<m; i++)
// if(b[i]!=b[i+1])
// a[j++]=b[i];
// m=j;
// do
// {
// x=map[0][a[0]];//计算的是0站和a[0]站的距离
// for(i=1; i<m; i++)
// x+=map[a[i-1]][a[i]];//以为地图的数据代表的是两站之间的距离,所以可以累加
// if(x<sum)
// sum=x;
// }
// while(next_permutation(a,a+m));//等于是遍历输入的站之间的二叉树排列,求出最短的距离
// printf("%d\n",sum);
// }
// return 0;
//}


最新文章

  1. flask_sqlalchemy 命名遇到的一个小坑
  2. bzoj4491奇技淫巧线段树
  3. linux数据误删后,灾难性数据备份与数据还原
  4. Log4J日志配置详解
  5. 关于break和continue的区别
  6. 盒图(boxplot)
  7. VS2010使用TTS
  8. ucos创建任务的一般方法
  9. 100 high quality blogs from java developers
  10. Servlet的生命周期?
  11. Linux启动新进程的几种方法及比较
  12. js 动态切换视频
  13. 如何生成转储(dmp)文件--工具篇
  14. 《An Industrial-Strength Audio Search Algorithm》译文
  15. spring-mybatis的整合
  16. 一次艰难debug的反思
  17. jsonp原理及同源策略
  18. 将LinkedHashMap转换为需要的对象
  19. java动态代理--一个简单的例子
  20. 提示:pip install --upgrade pip

热门文章

  1. oracle常见错误对应代码与含义
  2. 【译】第九篇 Replication:复制监视器
  3. beego项目运行过程
  4. Spring编程式和声明式事务实例讲解
  5. plsql链接数据库配置
  6. CentOS安装ANT
  7. docker 错误排查:无法进入容器.
  8. Django中的QuerySet
  9. java基础71 XML解析中的【DOM和SAX解析工具】相关知识点(网页知识)
  10. java基础69 JavaScript产生伪验证码(网页知识)