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

            統計

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

            留言簿(10)

            隨筆分類(70)

            隨筆檔案(182)

            文章檔案(1)

            如影隨形

            搜索

            •  

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            POJ 3268

            求從原點到達某個點之后返回,來回最長的距離是多少? 比較基礎的問題,兩遍Dijkstra就可以了。

               1:   
               2:  #include <iostream> 
               3:  #include <vector>
               4:  #include <algorithm>
               5:  #include <queue>
               6:  #include <string.h>
               7:  #include <stdio.h>
               8:  using namespace std;
               9:   
              10:  #define V   1005
              11:  #define E   100005
              12:  #define INF 329999         
              13:   
              14:  // v :the end point of an edge. w : the weight of the weight next:cluster according to the begin point of the edge
              15:  struct node
              16:  {
              17:      int v, w,next;
              18:      node(int vv=0, int ww=0):v(vv),w(ww){}
              19:      bool operator < (const node& r) const{return w> r.w;}
              20:  }pnt[E],pnt1[E];
              21:   
              22:  int e=0,N,M,s;
              23:   
              24:  int head[V];
              25:  int dis[V];
              26:  bool vis[V];
              27:  int src, sink;
              28:   
              29:  void Dijkstra()
              30:  { 
              31:      priority_queue<node> Q; 
              32:      vis[src] = 1; dis[src] = 0; 
              33:      Q.push(node(src, 0)); 
              34:      for (int u = src, i=1; i< N; i++)                 
              35:      { 
              36:          for (int j = head[u]; j != -1; j = pnt[j].next)    // j is edge number.
              37:          { 
              38:              int v = pnt[j].v;                          
              39:              if (vis[v] == 0 && dis[v] > dis[u] + pnt[j].w )// pre is the current vertex
              40:              { 
              41:                  dis[v] = dis[u] + pnt[j].w; 
              42:                  Q.push(node(v, dis[v]));
              43:              } 
              44:          } 
              45:          while (!Q.empty() && vis[Q.top().v]) Q.pop(); 
              46:          if (Q.empty()) break;
              47:          vis[u = Q.top().v] = 1; Q.pop();
              48:      }
              49:  } 
              50:  int head1[V];
              51:  inline void addedge1(int u, int v, int w)
              52:  {
              53:      pnt1[s].v =v; pnt1[s].w = w; pnt1[s].next = head1[u]; head1[u]=s++;
              54:  }
              55:  inline void addedge(int u, int v, int w){ 
              56:      pnt[e].v = v; pnt[e].w = w; pnt[e].next= head[u]; head[u]=e++;
              57:  } 
              58:   
              59:  void Dijkstra_init()
              60:  { 
              61:      e = 0; s =0;
              62:      memset(head, -1, sizeof(head)); 
              63:      memset(head1, -1, sizeof(head));
              64:      memset(vis, 0, sizeof(vis));
              65:      scanf("%d%d", &N , &M);
              66:      for (int i = 0; i <=N; i++) dis[i] = INF; 
              67:      scanf("%d", &src);
              68:      //cout<<src<<endl;
              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:          addedge1(b,a, c);
              75:      }
              76:   
              77:   
              78:  } 
              79:   
              80:  int main()
              81:  {
              82:      //freopen("3268.txt","r",stdin);
              83:   
              84:      Dijkstra_init();
              85:      Dijkstra();
              86:      int dis1[V];
              87:      for(int i=0; i<=N; i++) dis1[i] = dis[i];
              88:      //for(int i=1; i<=N; i++) cout<<dis[i]<<" "; cout<<endl;
              89:      memset(vis, 0 ,sizeof(vis));
              90:      for(int i=0; i<=N; i++) { dis[i]= INF; head[i] = head1[i];}
              91:      for(int i=0; i<M; i++)
              92:      {
              93:          pnt[i]=pnt1[i];
              94:   
              95:      }
              96:      Dijkstra();
              97:      //for(int i=1; i<=N; i++) cout<<dis[i]<<" "; cout<<endl;
              98:      int ret = 0;
              99:      for(int i=1; i<=N; i++) ret = max(ret, dis1[i]+dis[i]);
             100:      cout<<ret<<endl;
             101:      return 0;
             102:  }
             103:   

            posted on 2012-11-10 00:03 Sosi 閱讀(457) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm

            統計系統
            久久国产热精品波多野结衣AV| 久久精品国产一区| 久久久国产亚洲精品| 欧美日韩精品久久久免费观看| 久久久精品国产sm调教网站 | 99久久国产综合精品网成人影院| 欧美激情精品久久久久| 久久精品国产第一区二区| 久久亚洲sm情趣捆绑调教 | 久久人妻少妇嫩草AV蜜桃| 久久精品国产亚洲AV电影 | 久久久精品国产免大香伊 | 国产午夜精品久久久久免费视| 久久99精品九九九久久婷婷| 久久精品国产亚洲av麻豆蜜芽| 欧美精品一区二区精品久久| 伊人久久大香线蕉精品不卡| 99久久综合狠狠综合久久| 老色鬼久久亚洲AV综合| 久久综合五月丁香久久激情| 久久综合丁香激情久久| 97久久国产露脸精品国产| 热RE99久久精品国产66热| 亚洲午夜久久久精品影院 | 久久久久久午夜成人影院| 久久久久久久91精品免费观看| 曰曰摸天天摸人人看久久久| www.久久热| 久久99国产精品尤物| 久久夜色精品国产噜噜亚洲AV | 人妻少妇精品久久| 国内精品久久久久久久coent| 久久国产一区二区| 久久精品无码一区二区三区| 99久久精品影院老鸭窝| 奇米影视7777久久精品| 久久综合给合久久狠狠狠97色| 亚洲精品乱码久久久久久中文字幕| 久久人与动人物a级毛片| 波多野结衣久久一区二区| 伊人久久大香线蕉综合影院首页 |