• <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>

            O(1) 的小樂

            Job Hunting

            公告

            記錄我的生活和工作。。。
            <2012年11月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            統(tǒng)計

            • 隨筆 - 182
            • 文章 - 1
            • 評論 - 41
            • 引用 - 0

            留言簿(10)

            隨筆分類(70)

            隨筆檔案(182)

            文章檔案(1)

            如影隨形

            搜索

            •  

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            POJ 3159 SPFA

            給定一個圖,(V  3*10^4, E 1.5*10^5),如此大規(guī)模的圖,求一個最短路,只能使用SPFA(使用棧進(jìn)行優(yōu)化)

            https://github.com/Sosi/ProgrammingContest/blob/master/OnlineJudge/POJ/PKU3159.cpp

               1:  #include <queue>
               2:  #include <iostream>
               3:  #include <string.h>
               4:  #include <stdio.h>
               5:  using namespace std;
               6:  #define MAXN 30010      // vertex
               7:  #define MAXM 150010      // edge
               8:  #define INF 0x3F3F3F3F
               9:   
              10:  struct node
              11:  {
              12:      int v, w, next;
              13:  }pnt[MAXM];
              14:   
              15:  int head[MAXN];
              16:  int  dis[MAXN];
              17:  bool vis[MAXN];
              18:  int  cnt[MAXN];       // the number of the operation of push to Quque. negatvie cycle.
              19:  int num = 0;          // the index of the edge
              20:  int N ;               // the number of the vertex.
              21:  int M ;               // the number of edges
              22:  int src, sink;
              23:  void addedge(int  u, int v, int w)
              24:  {
              25:      pnt[num].v = v; pnt[num].w= w;
              26:      pnt[num].next = head[u]; head[u] = num++;
              27:  }
              28:   
              29:  int SPFA()
              30:  {
              31:      for(int i=0; i<=N; i++)
              32:      {
              33:          vis[i]=0; dis[i] = INF; cnt[i] = 0;
              34:      }
              35:   
              36:      int Q[MAXM], top=1;
              37:      Q[0] = src; vis[src] = 1;
              38:      dis[src] = 0;
              39:      while(top)
              40:      {
              41:          int u = Q[--top]; vis[u] = 0;
              42:          for(int i = head[u]; i!=-1; i=pnt[i].next)
              43:          {
              44:              int v = pnt[i].v;
              45:              if(dis[v]> dis[u] + pnt[i].w )
              46:              {
              47:                  dis[v]= dis[u] +pnt[i].w;
              48:                  if(!vis[v])
              49:                  {
              50:                      Q[top++] = v; vis[v]= 1;
              51:                  }
              52:              }
              53:   
              54:          }
              55:      }
              56:   
              57:   
              58:   
              59:      return dis[sink];
              60:  }
              61:   
              62:  int main()
              63:  {
              64:      //freopen("3159.txt", "r", stdin);
              65:      while(scanf("%d%d", &N , &M)!= EOF)
              66:      {
              67:          num = 0;
              68:          memset(head, -1, sizeof(head)); 
              69:          for(int i=0; i<M; i++)
              70:          {
              71:              int a, b, c;
              72:              scanf("%d%d%d", &a, &b, &c);
              73:              addedge(a, b,c);
              74:          }
              75:          //cout<<num<<endl;
              76:          src = 1; sink = N;
              77:          //cout<<"src "<<src<<" sink "<<N<<endl;
              78:          printf("%d\n", SPFA());
              79:      }
              80:      return 0;
              81:  }

            posted on 2012-11-09 21:15 Sosi 閱讀(388) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm

            統(tǒng)計系統(tǒng)
            无码超乳爆乳中文字幕久久| 亚洲国产成人精品女人久久久 | 性欧美丰满熟妇XXXX性久久久| 欧美一级久久久久久久大片| 久久久久久伊人高潮影院| 久久九九有精品国产23百花影院| 久久国产AVJUST麻豆| 色播久久人人爽人人爽人人片AV| 亚洲国产另类久久久精品小说| 国产三级久久久精品麻豆三级 | 久久香蕉国产线看观看精品yw| 日批日出水久久亚洲精品tv| 嫩草伊人久久精品少妇AV| 久久精品亚洲欧美日韩久久| 国产精品久久久久久久午夜片| 久久久青草久久久青草| 久久人妻AV中文字幕| 99久久人人爽亚洲精品美女| 精品久久久无码中文字幕| 久久精品国产精品亚洲| 色综合久久久久无码专区| 精品人妻伦一二三区久久| 久久99国产综合精品免费| 久久午夜夜伦鲁鲁片免费无码影视 | 久久99亚洲综合精品首页 | 久久99精品久久久久久野外| 99久久99久久久精品齐齐| 久久精品国产清高在天天线| 国产亚洲婷婷香蕉久久精品| 国产亚洲精久久久久久无码AV| 久久精品无码午夜福利理论片 | 93精91精品国产综合久久香蕉| 国内精品九九久久久精品| 伊人久久大香线蕉亚洲五月天| 久久综合综合久久综合| 亚洲色欲久久久综合网| 伊人久久大香线蕉综合影院首页| 久久中文精品无码中文字幕| 久久久久久曰本AV免费免费| 99精品国产99久久久久久97| 久久99久久99精品免视看动漫|