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

  1. 3
  2. 0 1 2
  3. 1 0 3
  4. 2 3 0
  5. 3
  6. 1 1 2
  7. 0

Sample Output

  1. 4
  1. #include<stdio.h>
  2. #include<algorithm>
  3. #include<string.h>
  4. using namespace std;
  5. int n,m,b[100],c[100],a[100],minlength;
  6. int map[100][100];
  7. void dfs(int step,int length,int last)
  8. {
  9. if(step==m)
  10. {
  11. minlength=min(length,minlength);
  12. return;
  13. }
  14. else
  15. {
  16. for(int i=0; i<m; i++)
  17. if(!b[i])
  18. {
  19. b[i]=1;
  20. dfs(step+1,length+map[last][a[i]],a[i]);
  21. b[i]=0;
  22. }
  23. }
  24. }
  25. int main()
  26. {
  27. while(~scanf("%d",&n),n)
  28. {
  29. int i,j;
  30. memset(b,0,sizeof(b));
  31. memset(c,0,sizeof(c));
  32. for(i=0; i<n; i++)
  33. for(j=0; j<n; j++)
  34. scanf("%d",&map[i][j]);
  35. scanf("%d",&m);
  36. for(i=0; i<m; i++)
  37. scanf("%d",&c[i]);
  38. sort(c,c+m);//先排序在去重
  39. for(j=i=0; i<m-1; i++)
  40. if(c[i]!=c[i+1])
  41. a[j++]=c[i];
  42. a[j]=c[i];
  43. m=j+1;
  44. minlength=0x3f3f3f3f;//最大值
  45. dfs(0,0,0);
  46. printf("%d\n",minlength);
  47. }
  48. return 0;
  49. }
  50.  
  51. //#include<iostream>
  52. //#include<queue>
  53. //#include<stdio.h>
  54. //#include<algorithm>
  55. //using namespace std;
  56. //int map[31][31],n;
  57. //int main()
  58. //{
  59. // int i,j,m,sum,a[10],b[10],x;
  60. // while(~scanf("%d",&n),n)
  61. // {
  62. // sum=999999;
  63. // for(i=0; i<n; i++)
  64. // for(j=0; j<n; j++)
  65. // scanf("%d",&map[i][j]);
  66. // scanf("%d",&m);
  67. // for(i=0; i<m; i++)
  68. // scanf("%d",&b[i]);
  69. // sort(b,b+m);
  70. // b[m]=-1;
  71. // for(j=i=0; i<m; i++)
  72. // if(b[i]!=b[i+1])
  73. // a[j++]=b[i];
  74. // m=j;
  75. // do
  76. // {
  77. // x=map[0][a[0]];//计算的是0站和a[0]站的距离
  78. // for(i=1; i<m; i++)
  79. // x+=map[a[i-1]][a[i]];//以为地图的数据代表的是两站之间的距离,所以可以累加
  80. // if(x<sum)
  81. // sum=x;
  82. // }
  83. // while(next_permutation(a,a+m));//等于是遍历输入的站之间的二叉树排列,求出最短的距离
  84. // printf("%d\n",sum);
  85. // }
  86. // return 0;
  87. //}


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. TIP协议

    1. TIP是什么? CISCO给TIP的定义如下: The TIP protocol specifications describe how to multiplex multiple screen ...

  2. centos6.4下配置nginx服务器更改根目录

    安装完nginx服务器后发现nginx的根目录在/usr/share/nginx/html/下,但是对于部署文件来说,在该目录下是不太习惯的,我就尝试着更改nginx访问的根目录 #  vi /etc ...

  3. Hive笔记之导出查询结果

    一.导出到本地 导出查询结果到本地: INSERT OVERWRITE LOCAL DIRECTORY "/tmp/hive-result/t_visit_video" SELEC ...

  4. 59、synchronized同步代码块

    synchronized同步方法的问题 有些情况下,在方法上面加synchronized同步,会有性能问题.请看下面代码,来计算下两个线程执行的耗时: package com.sutaoyu.Thre ...

  5. Oracle新建数据库,并导入dmp文件

    1:安装Oracle及新建数据库 Oracle 11g安装图解 http://www.cnblogs.com/qianyaoyuan/archive/2013/05/05/3060471.html h ...

  6. 关于UDP数据报引发“异步错误”的疑问

    在UNP卷一第三版的第8章8.9小节中说到:如果udp服务器没有启动,udp客户端在使用sendto发送一行文本后,将会等待一个永远也不会出现的应答从而阻塞在recvfrom调用上. 由于服务器段不存 ...

  7. 使用java8的StreamAPI对集合计算进行代码重构

    方法: 查询出所有部门成员中年龄大于30的员工姓名 部门对象: 员工对象: 模拟数据: private static List<Dept> list=new ArrayList<De ...

  8. vue中使用cookie记住用户上次选择(本次例子中为下拉框)

    最近工作中碰到一个需求,添加一条数据时,自动记住上次选择的下拉框的数据,刚开始觉得没思路,后来请教了项目组长,组长直接一句,这不很简单吧,直接用cookie,我:....... 好吧,都王的差不多了, ...

  9. RabbitMQ--Publish/Subscribe(三)

    前言 在先前例子中我们创建了一个work queue,封装一个task到一个message中并发送到queue.一个worker(consumer)取出任务并执行. 像这种producer把messa ...

  10. 09 Command Documentation 命令文档

    Command Documentation 命令文档   There is a suite of programs to build and process Go source code. Inste ...