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. Python练习-跨目录调用模块

    层级结构: dir1 ---hello.py dir2 ---main.py 其中,hello.py: def add(x,y): return x+y main.py如何能调用到hello.py中的 ...

  2. Linux下inittab文件详解

    /etc/inittab文件详解 Linux系统的启动过程为:加电自检-->根据BIOS中的设置从指定的设备启动-->找到设备MBR中的bootloader引导启动系统-->启动ke ...

  3. 自动检测SOCKET链接断开

    如何判断SOCKET已经断开 最近在做一个服务器端程序,C/S结构.功能方面比较简单就是client端与server端建立连接,然后发送消息给server.我在server端会使用专门的线程处理一条s ...

  4. 【FCS NOI2018】福建省冬摸鱼笔记 day1

    省冬的第一天. 带了本子,笔,一本<算法导论>就去了.惊讶于为什么同学不带本子记笔记. 他们说:“都学过了.”,果然这才是巨神吧. 第一天:数论,讲师:zzx 前几页的课件挺水,瞎记了点笔 ...

  5. 【Python项目】爬取新浪微博签到页

    基于微博签到页的微博爬虫 项目链接:https://github.com/RealIvyWong/WeiboCrawler/tree/master/WeiboLocationCrawler 1 实现功 ...

  6. 『实践』百度地图给map添加右键菜单(判断是否为marker)

      var map; var s;//经度 var w;//纬度 $(document).ready(function(){ $(".mune").load("jsp/c ...

  7. vue2.0组件之间的传值

    1.父子组件--props props:需要注意的是,虽然的是单向的数据流,但是如果传递的是数组或是对象这样的引用类型,子组件数据变化,父组件的数据通也会变化 子组件代码 <template&g ...

  8. java基础63 JavaScript中的Number、Math、String、Date对象(网页知识)

    本文知识点(目录): 1.Number对象    2.Math对象    3.String对象    4.Date对象 (日历例子) 1.Number对象 1.1.Number对象的创建方式 方式1: ...

  9. eclipse各种报错

    1.控制台报这个错是由于tomcat的session缓存的问题; org.apache.catalina.session.StandardManager doLoad 造成原因:上次未正确关闭tomc ...

  10. MyBatis3.4.0以上的分页插件错误:Could not find method on interface org.apache.ibatis.executor.statement.StatementHandler named prepare. Cause: java.lang.NoSuchMethodException: org.apache.ibatis.executor.stateme

    错误: Could not find method on interface org.apache.ibatis.executor.statement.StatementHandler named p ...