博客
关于我
【NOIP2012模拟8.7】找位置(暴力全排列)
阅读量:220 次
发布时间:2019-03-01

本文共 1302 字,大约阅读时间需要 4 分钟。


思路:K比较小,暴力预处理K次最短路不必说。问题在于哪种排列是最优的呢?采用全排列暴力,每种顺序按照一个环走一遍。

至于一条路走两遍以及以上的情况,在起点的枚举中会被包括进去。

#include
#include
#include
#include
#include
#include
#include
#include
#include
#define debug(a) cout<<#a<<"="<
<
P;///first最短距离,second顶点的编号struct edge{ LL to,cost;};struct SHOP{ LL id,pos;}shop[10];bool cmp(SHOP A,SHOP B){ return A.pos
g[maxn];LL vis[maxn];LL dis[maxn][10];LL n,m;void dijkstra(LL st,LL k){ LL s=st;///起点是st dis[s][k]=0; memset(vis,0,sizeof(vis));///初始化 priority_queue< P, vector

, greater

>que; que.push({0,s}); while(!que.empty()) { P p=que.top();que.pop(); int v=p.second; if(vis[v]) continue; vis[v]=1; for(int i=0;i

dis[v][k]+e.cost) { dis[e.to][k]=dis[v][k]+e.cost; que.push({dis[e.to][k],e.to}); } } }}int main(void){ memset(dis,0x3f,sizeof(dis));///初始化 LL n,m,k;n=read();m=read();k=read(); for(LL i=1;i<=k;i++){ shop[i].id=read(); shop[i].pos=i; } for(LL i=1;i<=m;i++){ LL u,v,cost;u=read();v=read();cost=read(); g[u].push_back({v,cost}); g[v].push_back({u,cost}); } for(LL i=1;i<=k;i++){ dijkstra(shop[i].id,shop[i].pos); } LL ans=0x3f3f3f3f3f3f3f3f; for(LL i=1;i<=n;i++){ bool flag=1; for(LL j=1;j<=k;j++){ if(shop[j].id==i){ flag=0; } } if(flag==0) continue; do{ LL sum=0; /// for(LL j=1;j<=k;j++) cout<
<<" "; /// cout<

 

转载地址:http://luct.baihongyu.com/

你可能感兴趣的文章
Java小白的入门之路
查看>>
少儿编程100讲轻松学python(一)-python怎么打开
查看>>
HDU - 6071 Lazy Running 同余最短路 + 分层
查看>>
leetCode 542 01矩阵(二维dp)
查看>>
《我的世界》Python编程入门(5) 租金游戏
查看>>
《我的世界》Python编程入门(7) 使用Python中的for循环语句放置多个方块
查看>>
顺序建表
查看>>
多余元素删除之移位算法
查看>>
linux -----创建用户 ,群组,权限
查看>>
Linux自学之旅-基础命令(管道符 | )
查看>>
Linux自学之旅-基础命令(系统痕迹之who命令)
查看>>
HCIA(计算机网络概念、网络协议模型意义)
查看>>
HCIA(OSI七层参考模型详解)
查看>>
设计模式一(工厂模式)
查看>>
CentOS安装java开发环境(输入javac无反应及解决办法)
查看>>
node.js手写http服务器连接mysql数据库
查看>>
css 设置背景图片铺满固定不动
查看>>
laravel server error 服务器内部错误
查看>>
yum 404
查看>>
漫谈Java理念的转变与JVM的五大优势
查看>>