这里介绍怎么求k短路

A*搜索 估价函数f[i]=g[i]+h[i];

在这里g[i]表示到达点i当前路径长,h[i]表示点i到达终点的最短距离

在搜索中,每次都取队列估价函数值最小的点,然后把它所能到达的点更新进入队列

显然这需要一个优先队列来维护(heap)

当终点第k次出队时,当前路径长度就是k短路

 const max=;
type link=^node;
     node=record
       po,len:longint;
       next:link;
     end;
     point=record
       data,num:longint;
     end;
var w,ow:array[..] of link;
    v:array[..] of boolean;
    d:array[..] of longint;
    heap:array[..] of point;   //堆维护估价函数值
    st,en,i,n,m,j,t,k,x,y,z,s:longint;
    p:link; procedure sift(x:longint);    //堆的下沉
  var i,j:longint;
  begin
    i:=x;
    j:=i*;
    while j<=t do
    begin
      if (j+<=t) and (heap[j].data>heap[j+].data) then inc(j);
      if heap[i].data>heap[j].data then
      begin
        swap(heap[i],heap[j]);
        i:=j;
        j:=i*;
      end
      else exit;
    end;
  end; procedure up(x:longint);   //堆的上浮
  var i,j:longint;
  begin
    i:=x;
    j:=i div ;
    while j> do
    begin
      if heap[i].data<heap[j].data then
      begin
        swap(heap[i],heap[j]);
        i:=j;
        j:=i div ;
      end
      else exit;
    end;
  end; procedure add(x,y:longint;var q:link);
  var p:link;
  begin
    new(p);
    p^.po:=y;
    p^.len:=z;
    p^.next:=q;
    q:=p;
  end; procedure dij;     //求点到终点的距离
  var p:link;
  begin
    fillchar(v,sizeof(v),false);
    v[en]:=true;
    for i:= to n do
      d[i]:=max;
    d[en]:=;
    p:=ow[en];
    while p<>nil do
    begin
      d[p^.po]:=min(d[p^.po],p^.len);   //用邻接表重要的细节
      p:=p^.next;
    end;
    for i:= to n- do
    begin
      x:=max;
      y:=;
      for j:= to n do
        if not v[j] and (d[j]<x) then
        begin
          x:=d[j];
          y:=j;
        end;
      if x=max then exit;
      v[y]:=true;
      p:=ow[y];
      while p<>nil do
      begin
        d[p^.po]:=min(d[p^.po],p^.len+x);
        p:=p^.next;
      end;
    end;
  end; function astar(st,ed:longint):longint;
  var p:link;
  begin
    heap[].data:=d[st];
    heap[].num:=st;
    t:=;
    s:=;
    astar:=-;
    while t<> do
    begin
      x:=heap[].num;    //退队
      y:=heap[].data-d[x];  
      swap(heap[],heap[t]);
      dec(t);
      sift();
      if x=en then
      begin
        s:=s+;
        if s=k then exit(y);
      end;
      p:=w[x];
      while p<>nil do      //更新所有能到达的点入队
      begin
        inc(t);
        heap[t].num:=p^.po;
        heap[t].data:=y+p^.len+d[p^.po];
        up(t);
        p:=p^.next;
      end;
    end;
  end; begin
  readln(n,m);
  for i:= to m do
  begin
    readln(x,y,z);
    add(x,y,w[x]);
    add(y,x,ow[y]);    //注意有向需反向建边,快速求点到终点的距离
  end;
  readln(st,en,k);
  if st=en then inc(k);  //注意终点与起点重合时,路径为0的不算
  dij;
   writeln(astar(st,en));
end.

而对于poj3255,求无向图的次短路也可以用A*,在n<=5000时还是可以过的,注意那时候就不需要反向建边了

k短路算法还是很好理解的

poj3255,poj2449的更多相关文章

  1. ACM训练计划step 2 [非原创]

    (Step2-500题)POJ训练计划+SGU 经过Step1-500题训练,接下来可以开始Step2-500题,包括POJ训练计划的298题和SGU前两章200题.需要1-1年半时间继续提高解决问题 ...

  2. POJ训练计划

    POJ训练计划 Step1-500题 UVaOJ+算法竞赛入门经典+挑战编程+USACO 请见:http://acm.sdut.edu.cn/bbs/read.php?tid=5321 一.POJ训练 ...

  3. Pyhton开源框架(加强版)

    info:Djangourl:https://www.oschina.net/p/djangodetail: Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC)风格的 ...

  4. MPlayer

    名称   mplayer − 电影播放器 mencoder − 电影编解码器 概要   mplayer [选项] [文件|URL|播放列表|−] mplayer [选项] 文件1 [指定选项] [文件 ...

  5. python 爬取腾讯微博并生成词云

    本文以延参法师的腾讯微博为例进行爬取并分析 ,话不多说 直接附上源代码.其中有比较详细的注释. 需要用到的包有 BeautifulSoup WordCloud jieba # coding:utf-8 ...

  6. 面经 cisco

    1. 优先级反转问题及解决方法 (1)什么是优先级反转 简单从字面上来说,就是低优先级的任务先于高优先级的任务执行了,优先级搞反了.那在什么情况下会生这种情况呢? 假设三个任务准备执行,A,B,C,优 ...

  7. linux驱动(续)

    网络通信 --> IO多路复用之select.poll.epoll详解 IO多路复用之select.poll.epoll详解      目前支持I/O多路复用的系统调用有 select,psel ...

  8. HttpServletRequest对象(一)

    javaweb学习总结(十)——HttpServletRequest对象(一) 一.HttpServletRequest介绍 HttpServletRequest对象代表客户端的请求,当客户端通过HT ...

  9. POJ3255 Roadblocks [Dijkstra,次短路]

    题目传送门 Roadblocks Description Bessie has moved to a small farm and sometimes enjoys returning to visi ...

随机推荐

  1. phpcms v9 源码解析- 2 base.php

    base.php在上文已经说过,是在PC中重要的一个文件,基本常量.核心类文件的加载都由它来完成. 9行,定义了一个常量 IN_PHPCMS,在系统的入口定义一个常量,在其他文件就判断是否这个常量被定 ...

  2. class_create(),device_create自动创建设备文件结点

    class_create(),device_create自动创建设备文件结点 从linux 内核2.6的某个版本之后,devfs不复存在,udev成为devfs的替代.相比devfs,udev有很多优 ...

  3. Js 处理将时间转换 “年-月-日”

    将时间  \/Date(1432828800000+0800)\/"  转换成:“年-月-日” //时间转换function ChangeDateFormat(val) {    if (v ...

  4. iOS 支付宝应用(备用参考2)

    接入前期准备工作包括商户签约和密钥配置 步骤1:  启动IDE(如Xcode),把iOS包中的压缩文件中以下文件拷贝到项目文件夹下, 并导入到项目工程中. AlipaySDK.bundle    Al ...

  5. poj 3013 Big Christmas Tree (最短路径Dijsktra) -- 第一次用优先队列写Dijsktra

    http://poj.org/problem?id=3013 Big Christmas Tree Time Limit: 3000MS   Memory Limit: 131072K Total S ...

  6. [搜片神器]BT管理程序数据库速度调试优化问题

    DHT抓取程序开源地址:https://github.com/h31h31/H31DHTDEMO 数据处理程序开源地址:https://github.com/h31h31/H31DHTMgr 谢谢园子 ...

  7. 使用Yeoman搭建 AngularJS 应用 (8) —— 让我们搭建一个网页应用

    原文地址:http://yeoman.io/codelab/write-app.html 创建一个新的模板来显示一个todo的列表 打开views/main.html 为了从一个干净的模板开始,删除m ...

  8. c#无标题窗体点击任务栏图标正常最小化或还原

    FormBorderStyle等于System.Windows.Forms.FormBorderStyle.None的窗体,点击任务栏图标的时候,是不能象标准窗体那样最小化或还原的. protecte ...

  9. CQRS学习——集成ASP.NET Identity[其五]

    [其实和Cqrs没啥关系] 缘由 其实没啥原因,只是觉得以前写了不知多少遍的用户登录复用性太差,实现的功能也不多. 依赖的Nuget包 简单登陆 就简单登陆而言,只需要实现如下接口/抽象类: Stor ...

  10. 【数学/扩展欧几里得/Lucas定理】BZOJ 1951 :[Sdoi 2010]古代猪文

    Description “在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心……” ——选自猪王国民歌 很久很久以前,在山的那边 ...