青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

Bellman-Ford && SPFA 算法

Posted on 2010-10-23 22:09 MiYu 閱讀(953) 評論(0)  編輯 收藏 引用 所屬分類: ACM ( 圖 )ACM_資料

MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋    

 

 B-F 

適用條件&范圍

  1. 單源最短路徑(從源點s到其它所有頂點v);
  2. 有向圖&無向圖(無向圖可以看作(u,v),(v,u)同屬于邊集E的有向圖);
  3. 邊權可正可負(如有負權回路輸出錯誤提示);
  4. 差分約束系統;

算法描述

  1. 對每條邊進行|V|-1次Relax ( 就是松弛操作 )操作;
  2. 如果存在(u,v)∈E使得dis[u]+w<dis[v],則存在負權回路;否則dis[v]即為s到v的最短距離,pre[v]為前驅。
For i:=1 to |V|-1 do //v為頂點數
For 每條邊(u,v)∈E do  //對每條邊進行遍歷
  Relax(u,v,w);
For每條邊(u,v)∈E do
  If dis[u]+w<dis[v] Then Exit(False)

時空復雜度

算法時間復雜度O(VE)。因為算法簡單,適用范圍又廣,雖然復雜度稍高,仍不失為一個很實用的算法。

 

算法的改進---> SPFA 

 

算法簡介

SPFA(Shortest Path Faster Algorithm)是Bellman-Ford算法的一種隊列實現,減少了不必要的冗余計算。也有人說SPFA本來就是Bellman-Ford算法,現在廣為流傳的Bellman-Ford算法實際上是山寨版。

算法流程

算法大致流程是用一個隊列來進行維護。 初始時將源加入隊列。 每次從隊列中取出一個元素,并對所有與他相鄰的點進行松弛,若某個相鄰的點松弛成功,則將其入隊。 直到隊列為空時算法結束。

這個算法,簡單的說就是隊列優化的bellman-ford,利用了每個點不會更新次數太多的特點發明的此算法

SPFA——Shortest Path Faster Algorithm,它可以在O(kE)的時間復雜度內求出源點到其他所有點的最短路徑,可以處理負邊。SPFA的實現甚至比Dijkstra或者Bellman_Ford還要簡單:

設Dist代表S到I點的當前最短距離,Fa代表S到I的當前最短路徑中I點之前的一個點的編號。開始時Dist全部為+∞,只有Dist[S]=0,Fa全部為0。

維護一個隊列,里面存放所有需要進行迭代的點。初始時隊列中只有一個點S。用一個布爾數組記錄每個點是否處在隊列中。

每次迭代,取出隊頭的點v,依次枚舉從v出發的邊v->u,設邊的長度為len,判斷Dist[v]+len是否小于Dist[u],若小于則改進Dist[u],將Fa[u]記為v,并且由于S到u的最短距離變小了,有可能u可以改進其它的點,所以若u不在隊列中,就將它放入隊尾。這樣一直迭代下去直到隊列變空,也就是S到所有的最短距離都確定下來,結束算法。若一個點入隊次數超過n,則有負權環。

SPFA 在形式上和寬度優先搜索非常類似,不同的是寬度優先搜索中一個點出了隊列就不可能重新進入隊列,但是SPFA中一個點可能在出隊列之后再次被放入隊列,也就是一個點改進過其它的點之后,過了一段時間可能本身被改進,于是再次用來改進其它的點,這樣反復迭代下去。設一個點用來作為迭代點對其它點進行改進的平均次數為k,有辦法證明對于通常的情況,k在2左右

算法代碼

Procedure SPFA;
 
Begin
  initialize-single-source(G,s);
  initialize-queue(Q);
  enqueue(Q,s);
  while not empty(Q) do 
    begin
      u:=dequeue(Q);
      for each v∈adj[u] do 
        begin
          tmp:=d[v];
          relax(u,v);
          if (tmp<>d[v]) and (not v in Q) then
            enqueue(Q,v);
        end;
    end;
End;


procedure spfa;
begin
  fillchar(q,sizeof(q),0); h:=0; t:=0;//隊列
  fillchar(v,sizeof(v),false);//v[i]判斷i是否在隊列中
  for i:=1 to n do 
    dist[i]:=maxint;//初始化最小值
 
  inc(t);
  q[t]:=1;
  v[1]:=true;
  dist[1]:=0;//這里把1作為源點
 
  while h<>t do
    begin
      h:=(h mod n)+1;
      x:=q[h];
      v[x]:=false;
      for i:=1 to n do
        if (cost[x,i]>0) and (dist[x]+cost[x,i]<dist[i]) then
          begin
            dist[i]:=dist[x]+cost[x,i];
            if not(v[i]) then
              begin
                t:=(t mod n)+1;
                q[t]:=i;
                v[i]:=true;
              end;
          end;
    end;
end;
void SPFA(void)//好久以前寫的……今天丟上來……話說我都不記得SPFA怎么寫了……囧……ms存圖是矩陣……嗯嗯
{
 int i;
 queue list;
 list.insert(s);
 for(i=1;i<=n;i++)
  {
   if(s==i)
    continue;
   dist[i]=map[s][i];
   way[i]=s;
   if(dist[i])
   list.insert(i);
  }
 int p;
 while(!list.empty())
 {
  p=list.fire();
  for(i=1;i<=n;i++)
   if(map[p][i]&&(dist[i]>dist[p]+map[p][i]||!dist[i])&&i!=s)
    {
     dist[i]=dist[p]+map[p][i];
     way[i]=p;
     if(!list.in(i))
      list.insert(i);
    }
 }
} 

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧美成人一区二区在线电影| 玖玖玖免费嫩草在线影院一区| 欧美一区=区| 一区二区三区日韩在线观看| 亚洲精品无人区| 9l国产精品久久久久麻豆| 亚洲精品在线免费观看视频| 亚洲国产日韩在线一区模特| 国产欧美日韩一区| 欧美大片专区| 欧美日一区二区在线观看| 欧美午夜激情在线| 国产亚洲永久域名| 亚洲国产综合91精品麻豆| 日韩午夜激情av| 欧美一级播放| 亚洲福利视频一区| 一本不卡影院| 久久久久综合| 国产精品成人在线| 樱桃国产成人精品视频| 一区二区三区国产盗摄| 久久日韩粉嫩一区二区三区| 亚洲精品一区二区三区蜜桃久 | 久久精品国产77777蜜臀| 欧美福利视频网站| 国产日韩精品入口| 一本色道久久精品| 麻豆freexxxx性91精品| 亚洲最新视频在线播放| 久久免费高清| 国产女优一区| 亚洲一区3d动漫同人无遮挡| 男人的天堂亚洲在线| 亚洲女性喷水在线观看一区| 欧美激情欧美狂野欧美精品| 国产亚洲欧美aaaa| 午夜精品一区二区三区四区 | 久久国产66| 99成人精品| 欧美sm重口味系列视频在线观看| 国产精品美女久久久免费| 日韩西西人体444www| 欧美v亚洲v综合ⅴ国产v| 欧美一区二区三区啪啪| 国产精品视频专区| 亚洲综合视频一区| 亚洲美女视频网| 欧美激情综合色| 亚洲人成久久| 亚洲国产精品久久人人爱蜜臀| 久久精品成人欧美大片古装| 国产精品伊人日日| 羞羞视频在线观看欧美| 亚洲一区二区在线看| 国产精品久久久久久福利一牛影视| 亚洲美女网站| 日韩视频免费大全中文字幕| 欧美韩国一区| 一区二区三区国产精华| 日韩视频欧美视频| 亚洲欧美日韩一区| 日韩午夜剧场| 亚洲精品国产系列| 欧美激情视频免费观看| 亚洲精品午夜| 99爱精品视频| 国产精品呻吟| 久久亚洲不卡| 美女精品在线| 中文在线不卡视频| 亚洲免费伊人电影在线观看av| 国产精品久久久久久久久久尿 | 欧美日韩精品免费 | 黑人一区二区三区四区五区| 久久久久久九九九九| 久久久久久久欧美精品| 亚洲国产精品t66y| 亚洲精一区二区三区| 国产精品国产福利国产秒拍 | 欧美影院久久久| 久久久久久久网| 一本色道久久综合| 亚洲欧美日韩视频一区| 伊人狠狠色丁香综合尤物| 91久久国产综合久久蜜月精品 | 久久成人免费网| 久久久久久久久久久一区 | 欧美激情一区二区三区| 亚洲一区二区3| 久久国产精品99国产| 亚洲精品乱码久久久久久蜜桃91| 亚洲精品一线二线三线无人区| 国产精品色午夜在线观看| 美女视频黄 久久| 欧美性猛交xxxx乱大交蜜桃| 久久香蕉精品| 国产精品盗摄一区二区三区| 老司机免费视频久久| 欧美体内谢she精2性欧美| 麻豆精品视频在线观看视频| 欧美日韩国产免费观看| 久久久精品午夜少妇| 欧美日韩理论| 欧美福利网址| 国产综合亚洲精品一区二| 99热在线精品观看| 91久久精品国产91性色| 欧美一区久久| 欧美一级理论性理论a| 欧美极品在线播放| 美女精品自拍一二三四| 国产精品网站在线观看| 欧美日韩国产综合久久| 伊人色综合久久天天| 9l国产精品久久久久麻豆| 好看的日韩av电影| 亚洲欧美日韩天堂一区二区| 一本色道久久99精品综合| 久久伊伊香蕉| 久久精品123| 国产精品久久久久久一区二区三区 | 欧美激情成人在线| 国内外成人免费激情在线视频网站 | 亚洲视频在线观看三级| 一本色道婷婷久久欧美| 美女诱惑黄网站一区| 久久久久一区二区| 国产精品系列在线| 亚洲一区二区三区高清| 国产精品99久久不卡二区| 欧美伦理在线观看| 99精品视频免费观看视频| 日韩视频不卡| 欧美三级电影一区| 亚洲伦理在线观看| 中国成人黄色视屏| 欧美视频在线观看视频极品| 亚洲理伦在线| 中文国产亚洲喷潮| 国产精品分类| 性久久久久久久久| 免费看亚洲片| 亚洲美女av黄| 欧美日韩美女在线观看| 一区二区三区不卡视频在线观看 | 国产欧美亚洲视频| 欧美亚洲视频在线看网址| 久久久蜜桃一区二区人| 在线日本欧美| 欧美久久久久中文字幕| 日韩一区二区福利| 性高湖久久久久久久久| 国产一区二区无遮挡| 久久久久一区| 99在线热播精品免费| 欧美一级黄色网| 1024成人| 国产精品jvid在线观看蜜臀| 小嫩嫩精品导航| 欧美国产成人在线| 中文av一区二区| 好吊妞这里只有精品| 欧美精品成人在线| 小黄鸭精品aⅴ导航网站入口| 欧美电影打屁股sp| 亚洲女同在线| 亚洲国产经典视频| 国产精品视频yy9299一区| 久久精品中文字幕一区| 欧美三区美女| 中文精品视频| 久久这里只精品最新地址| 99精品久久| 韩国av一区二区三区四区| 欧美成年人视频网站| 亚洲一区二区三区高清| 欧美大片免费观看| 久久国产一区二区| 一区二区三区久久久| 国内精品视频在线播放| 欧美日韩在线播放一区二区| 久久精品免费播放| 99riav国产精品| 欧美韩国日本一区| 久久久久亚洲综合| 性色一区二区| 中文国产亚洲喷潮| 亚洲精选中文字幕| 在线观看亚洲精品视频| 国产精品永久免费在线| 欧美日韩综合视频| 欧美精品在线极品| 欧美成人在线影院| 久久久久综合网| 久久精品国产视频| 欧美一级大片在线免费观看| 亚洲网站在线| 一区二区三区免费看| 日韩视频一区二区|