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;
//}


hdu1527下沙小面的(二)的更多相关文章

  1. C - 下沙小面的(2)

    C – 下沙小面的(2)Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64uSubmit StatusDes ...

  2. ESA2GJK1DH1K微信小程序篇: 测试微信小程序扫描Air202上面的二维码绑定设备,并通过MQTT控制设备

    前言 一,微信小程序篇小程序下载(该功能为小程序篇基础功能源码) 实现功能概要 微信小程序通过扫描GPRS上的二维码,绑定GPRS设备.然后使用小程序通过GPRS远程控制开发板上的继电器, 远程显示单 ...

  3. 微信小程序二维码推广统计

    微信小程序可以通过生成带参数的二维码,那么这个参数是可以通过APP的页面进行监控的 这样就可以统计每个二维码的推广效果. 今天由好推二维码推出的小程序统计工具HotApp小程序统计也推出了带参数二维码 ...

  4. SQL开发中容易忽视的一些小地方(二)

    原文:SQL开发中容易忽视的一些小地方(二) 目的:继上一篇:SQL开发中容易忽视的一些小地方(一) 总结SQL中的null用法后,本文我将说说表联接查询. 为了说明问题,我创建了两个表,分别是学生信 ...

  5. [转]QGis2.9在windows下的编译以及二次开发包下载

    今天心血来潮,将QGis在github上的代码更新后,又编译了一下.留意到源代码包里面的INSTALL文件有更新,于是本次编译完全基于官方的编译说明.编译过程非常顺利,除了在CMake的第一次conf ...

  6. hdu 1267 下沙的沙子有几粒? (递推)

    下沙的沙子有几粒? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total S ...

  7. Vue小项目二手书商城:(二)axios前后端数据交互

    实现内容: 写路由接口(express) axios取数据 一.写接口 1.我们要在前端取到后端的数据(之前写的data.json)可以用vue-resourse或者用axios,在vue2之后官方就 ...

  8. Vue小项目二手书商城:(一)准备工作、组件和路由

    本项目基于vue2.5.2,与低版本部分不同之处会在(五)参考资料中提出 完整程序:https://github.com/M-M-Monica/bukesi 实现内容: 资源准备(mock数据) 组件 ...

  9. HDU——1267 下沙的沙子有几粒?

    下沙的沙子有几粒? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total ...

随机推荐

  1. Spring---七大核心模块

    核心容器(Spring Core) 核心容器提供Spring框架的基本功能.Spring以bean的方式组织和管理Java应用中的各个组件及其关系.Spring使用BeanFactory来产生和管理B ...

  2. springCloud全实战超详细代码demo+笔记

    码云: https://gitee.com/houzheng1216/springcloud

  3. 洛谷 P3307: bzoj 3202: [SDOI2013] 项链

    题目传送门:洛谷P3307.这题在bzoj上是权限题. 题意简述: 这题分为两个部分: ① 有一些珠子,每个珠子可以看成一个无序三元组.三元组要满足三个数都在$1$到$m$之间,并且三个数互质,两个珠 ...

  4. 【bzoj题解】题解传送门

    如题,题解传送门: 1001 1008 1012

  5. MIUI7,Android版本5.0.2,一个程序发送自定义广播,另一个程序没有接收到

    对照<第一行代码——Android>进行学习,第五章中说到广播包的相关知识,前面获取广播等程序例程都可以跑的通,但是在5.3.2节中,程序A发送自定义广播,并接收自定义广播,同时程序B也接 ...

  6. openjudge-NOI 2.5-1789 算24

    题目链接:http://noi.openjudge.cn/ch0205/1789/ 题解: 并不是非常简单的搜索,需要考虑一些东西…… 首先有运算符优先级的限制,还有括号,数字的顺序也可以调整,如果只 ...

  7. js API

    从基础知识JS-web-API js基础知识:ECMA 262标准 js-web-API: w3c标准 W3c标准中关于js的规定有 DOM操作.BOM操作.事件绑定.ajax请求(包括http协议) ...

  8. python基础--shutil模块

    shutil模块提供了大量的文件的高级操作. 特别针对文件拷贝和删除,主要功能为目录和文件操作以及压缩操作.对单个文件的操作也可参见os模块. 注意 即便是更高级别的文件复制函数(shutil.cop ...

  9. hive数据倾斜问题

    卧槽草草 来源于其它博客: 貌似我只知道group by key带来的倾斜 hive在跑数据时经常会出现数据倾斜的情况,使的作业经常reduce完成在99%后一直卡住,最后的1%花了几个小时都没跑完, ...

  10. 练习题 --- 写出5种css定位语法

    写出至少5种css语法(每种语法不一样)