• <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年6月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            1234567

            統(tǒng)計

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

            留言簿(10)

            隨筆分類(70)

            隨筆檔案(182)

            文章檔案(1)

            如影隨形

            搜索

            •  

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            POJ 3268

            求從原點到達某個點之后返回,來回最長的距離是多少? 比較基礎(chǔ)的問題,兩遍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 閱讀(462) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm

            統(tǒng)計系統(tǒng)
            亚洲AV日韩精品久久久久久久| 五月丁香综合激情六月久久| 精品乱码久久久久久夜夜嗨 | 婷婷久久综合九色综合九七| 7777精品伊人久久久大香线蕉| 中文国产成人精品久久不卡| 99久久精品国产麻豆| 日韩电影久久久被窝网| 久久精品亚洲日本波多野结衣 | 精品国产福利久久久| 热久久国产欧美一区二区精品| 一本一本久久aa综合精品| 国产精品免费久久久久久久久| 久久精品视频一| 99久久精品国产毛片| 人妻无码αv中文字幕久久 | 久久久久亚洲AV无码去区首| 亚洲女久久久噜噜噜熟女| 久久久99精品成人片中文字幕| 日韩人妻无码一区二区三区久久 | 久久久精品国产sm调教网站| 久久久中文字幕日本| 欧美激情精品久久久久| 7777精品久久久大香线蕉| 亚洲精品国产综合久久一线| 99久久亚洲综合精品成人| 国产成年无码久久久久毛片| 国产精品久久久香蕉| 日本国产精品久久| 日韩影院久久| 2021国产精品午夜久久| 久久精品国产亚洲AV不卡| 精品久久久久久无码人妻热| 99久久精品国内| 国产精品一久久香蕉国产线看| 久久亚洲欧美国产精品| 欧洲成人午夜精品无码区久久 | 麻豆久久久9性大片| 无码任你躁久久久久久老妇App| 亚洲色欲久久久久综合网| 久久亚洲精品无码VA大香大香|