旅行(travel)

从前有一位旅者,他想要游遍天下所有的景点。这一天他来到了一个神奇的王国:在这片土地上,有n个城市,从1到n进行编号。王国中有m条道路,第i条道路连接着两个城市ai,bi,由于年代久远,所有的道路都已经不能使用。如果要修复第i条道路,需要wi的时间。为了更好的旅行,旅者想要将某些道路修复,使得1号城市能够到达n号城市,2号城市能够到达n-1号城市..k号城市能够到达n-k+1号城市。为了满足他的要求,请问最少需要多少时间去修复道路。无解请输出-1。

输入格式:

第一行:n,m,k
接下来m行:ai,bi,wi
含义如上所述。

输出格式:

输出共一行:最少需要多少时间修复道路。如果始终无法满足旅者的要求,请输出-1。

样例输入:

5 5 2
1 3 4
3 5 2
2 3 1
3 4 4
2 4 3

样例输出:

9

数据范围:

20%的数据满足:k <= 2, n<= 10, m <= 20
40%的数据满足:k <= 3, n<=100, m<=1000
70%的数据满足:k<=4, n<=1000, m<=1000
100%的数据满足:k<=4, n<=10000, m<=10000, n >= 2*k, wi <= 1000, 1 <= ai, bi <= n 

时间限制:

3000

咋一看本题突然就想到要用生成树,然后仔细观察,发现这个k小得莫名其妙,于是弄出了一个暴枚+SPFA的算法,枚举每组i到n-k+i的顺序,再把最短路长度全部清零,取每种排列的最小值。
 #include<iostream>
 #include<queue>
 #include<cstdio>
 #include<cstring>
 using namespace std;
 ;
 struct node{
     int from,to,next,dis,bro;
 }edge[N*];
 ,dis[N],ans=,last[N];
 ],in[N],can=true;
 inline void unite(int x,int y,int w,int b)
 {
     edge[s].from=x;
     edge[s].bro=b;
     edge[s].to=y;
     edge[s].dis=w;
     edge[s].next=head[x];
     head[x]=s;
     return;
 }
 inline ;return;}
 inline void dfs(int step,int res)
 {
     if(step==k)
     {
         ans=min(ans,res);
         return;
     }
     if(!can) return;
     node store[N*];
     ;i<=s;i++) store[i]=edge[i];
     ;
     ;u<=k;u++) )
     {
         used[u]=;
         ) ;i<=s;i++) edge[i]=store[i];
         ;
         queue<int> Q;
         memset(dis,,sizeof(dis));
         memset(last,,sizeof(last));
         ];
         dis[u]=;
         Q.push(u);
         while(!Q.empty())
         {
             int f=Q.front();
             Q.pop();
             ;
             for(int i=head[f];i;i=edge[i].next) if(edge[i].dis+dis[f]<dis[edge[i].to])
             {
                 dis[edge[i].to]=edge[i].dis+dis[f];
                 last[edge[i].to]=i;
                 if(!in[edge[i].to])
                 {
                     Q.push(edge[i].to);
                     ;
                 }
             }
         }
         ]) can=;
         else
         {
             ;
             )
             {
                 del(last[p]);
                 del(edge[last[p]].bro);
                 p=edge[last[p]].from;
             }
             dfs(step+,res+dis[n-u+]);
         }
         used[u]=;
     }
     return;
 }
 int main()
 {
     int x,y,w;
     scanf("%d%d%d",&n,&m,&k);
     ;i<=m;i++)
     {
         scanf("%d%d%d",&x,&y,&w);
         s++;unite(x,y,w,s+);
         s++;unite(y,x,w,s-);
     }
     memset(used,,sizeof(used));
     dfs(,);
     if(!can) printf("-1\n");
     else printf("%d\n",ans);
     ;
 }

GDOI2014模拟 旅行【SPFA】的更多相关文章

  1. 【JZOJ6419】模拟旅行&【BZOJ5506】【luoguP5304】旅行者

    description 某国有n座城市,这些城市之间通过m条单向道路相连,已知每条道路的长度. 不过,小X只对其中k座城市感兴趣. 为了更好地规划模拟旅行路线,提升模拟旅行的体验,小X想要知道他感兴趣 ...

  2. 【GDOI2014模拟】JZOJ2020年8月14日提高组 服务器

    [GDOI2014模拟]JZOJ2020年8月14日提高组 服务器 题目 Time and Memory Limits Description 我们需要将一个文件复制到n个服务器上,这些服务器的编号为 ...

  3. 【GDOI2014模拟】JZOJ2020年8月14日T2 网格

    [GDOI2014模拟]JZOJ2020年8月14日T2 网格 题目 Time and Memory Limits Description 某城市的街道呈网格状,左下角坐标为A(0, 0),右上角坐标 ...

  4. [JZOJ3400] 【GDOI2014模拟】旅行

    题目 题目大意 给你一个图,让你选择权值和最小的边,使得\(1\)和\(n\),\(2\)和\(n-1\),--,\(K\)和\(n-K+1\)联通. \(K\leq 4\) 思考历程 一看到这题就觉 ...

  5. All Roads Lead to Rome(30)(MAP【int,string】,邻接表,DFS,模拟,SPFA)(PAT甲级)

    #include<bits/stdc++.h>using namespace std;map<string,int>city;map<int,string>rcit ...

  6. GDOI2014模拟pty爬山(mountain)

    pty爬山(mountain) 在Pty学校附近,有一座名之为岳之麓的高山.Pty很喜欢和(哔--)一起爬山.山的平面模型如下:山由一个顶点集:A1,A2-An给定,保证Ai的x单调递增.我们将Ai和 ...

  7. 【GDOI2014模拟】服务器

    前言 直到比赛最后几分钟,才发现60%数据居然是一个水dp,结果没打完. 题目 我们需要将一个文件复制到n个服务器上,这些服务器的编号为S1, S2, -, Sn. 首先,我们可以选择一些服务器,直接 ...

  8. 【GDOI2014模拟】Tree

    题目 Wayne 在玩儿一个很有趣的游戏.在游戏中,Wayne 建造了N 个城市,现在他想在这些城市间修一些公路,当然并不是任意两个城市间都能修,为了道路系统的美观,一共只有M 对城市间能修公路,即有 ...

  9. 【GDOI2014模拟】网格

    题目 某城市的街道呈网格状,左下角坐标为A(0, 0),右上角坐标为B(n, m),其中n >= m.现在从A(0, 0)点出发,只能沿着街道向正右方或者正上方行走,且不能经过图示中直线左上方的 ...

随机推荐

  1. "ORA-01460: 转换请求无法实现或不合理"及C#操作Blob总结

    class BlobDemo { private static readonly string ConnectionString = "Data Source=Tcco;User ID=sc ...

  2. Javascript事件绑定及深入

    由于开学后的编程实验课,接触了海量字符换搜索的实验,所以好几天没有学习JS课程了,今天继续学习事件绑定. 传统事件绑定存在一些问题,如:同名事件函数都执行,第二个函数会覆盖第一个. 下面我们以事件切换 ...

  3. 两款【linux字符界面下】显示【菜单】,【选项】的powershell脚本模块介绍

    两款[linux字符界面下]显示[菜单],[选项]的powershell脚本模块介绍 powershell linux  ps1 menu choice Multiselect 传教士 菜单 powe ...

  4. 利刃 MVVMLight 4:绑定和绑定的各种使用场景

    一.绑定: 主要包含元素绑定和非元素绑定两种. 1.元素绑定,是绑定的最简单形式,源对象是WPF的元素,并且源对象的属性是依赖项属性. 根据我们之前的知识 ,依赖项属性具有内置的更改通知支持.所以当我 ...

  5. 信号处理——Hilbert端点效应浅析

    作者:桂. 时间:2017-03-05  19:29:12 链接:http://www.cnblogs.com/xingshansi/p/6506405.html 声明:转载请注明出处,谢谢. 前言 ...

  6. 类比Spring框架来实现OC中的依赖注入

    如果你之前使用过JavaEE开发中的Spring框架的话,那么你一定对依赖注入并不陌生.依赖注入(DI: Dependency Injection)是控制反转(IoC: Inversion of Co ...

  7. Think PHP 基础

    ThinkPHP 一.什么框架: 一堆代码的集合,里边有变量.函数.类.常量,里边也有许多设计模式MVC.AR数据库.单例等等. 框架可以节省我们50-60%的工作量,我们全部精力都集中在业务层次. ...

  8. 调试时a标签禁止跳转方法

    a.setAttribute("onclick",'');

  9. 关于JavaScript简单描述

    1.什么是JavaScript? JavaScript 是一种专门用于与网页交互而设计的脚本语言,它有三部分组成,那是哪三部分呢?分别是ECMAScript(提供核心语言功能),DOM(提供访问和操作 ...

  10. 2017,科学使用strace神器(附代码,举栗子)

    我感到惊讶,都2017年了,几乎没有人知道他们可以使用strace的了解所有事情.它总是我拔出的第一个调试工具之一,因为它通常在我运行的Linux系统上可用,并且它可以用于解决各种各样的问题. 什么是 ...