这里介绍怎么求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. 如何快速建立Subversion服务器

    本文拷贝自网址:http://www.subversion.org.cn/?action-viewnews-itemid-1 如何快速建立Subversion服务器,并且在项目中使用起来,这是大家最关 ...

  2. phonegap + 推送 + 页面跳转 (ios)

    os如果没有页面跳转的需求的话就使用极光推送,如果有页面跳转如果用了极光推送就只有用oc去写,但是我不会oc,所以智能放弃极光选用ios自己的apns来实现 新建项目跟安卓创建项目差不多,新建完成后就 ...

  3. mvc 之 @Html.DropDownList

    Dictionary<string, string> myDic = new Dictionary<string, string>(); myDic.Add(System.DB ...

  4. linux set,env和export

    set,env和export这三个命令都可以用来显示shell变量 set 显示当前shell的变量,包括当前用户的变量 env 显示当前用户的变量 export 显示当前导出成用户变量的shell变 ...

  5. easy ui 下拉级联效果 ,下拉框绑定数据select控件

    html代码: ①两个下拉框,一个是省,另一个市 <tr> <td>省:</td> <td> <select id="ProvinceI ...

  6. WP8.1和Win8.1的不同之处

    本文仅是个人见解,如有不足或错误之处欢迎批评指正~ 1.Toast: 创建Toast代码差不多但实现机制及管理上不一样 2.ApplicationData: WP8.1多了一个LocalCacheFo ...

  7. Get the item a SharePoint workflow task is associated with

    This is handy. SharePoint helpfully populates the meta data with the GUID of the list and the ID of  ...

  8. mvc权限,登陆,异常

    public class FilterOfPer : ActionFilterAttribute     {         public override void OnActionExecutin ...

  9. (转)深入理解SP、LR和PC

    网址:http://blog.csdn.net/zhou1232006/article/details/6149548 深入理解ARM的这三个寄存器,对编程以及操作系统的移植都有很大的裨益. 1.堆栈 ...

  10. java 取小数点后两位 不四舍五入,怎么做

    java 取小数点后两位 不四舍五入,怎么做 正常版: //正常版: import java.text.DecimalFormat; import java.math.RoundingMode; De ...