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

            公告

            記錄我的生活和工作。。。
            <2010年10月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統計

            • 隨筆 - 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 閱讀(469) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm

            統計系統
            久久综合狠狠综合久久激情 | 亚洲乱码中文字幕久久孕妇黑人| 久久综合给久久狠狠97色| 久久综合视频网站| 久久影院久久香蕉国产线看观看| 色综合久久88色综合天天| 狠狠精品久久久无码中文字幕 | 99久久精品免费| 国产一区二区三区久久精品| 91精品久久久久久无码| 久久久久久久久久免免费精品| 久久国产精品国语对白| 久久无码一区二区三区少妇 | 久久影视综合亚洲| 久久天天躁狠狠躁夜夜2020一| 久久国产免费直播| 99久久精品午夜一区二区 | 午夜视频久久久久一区 | 国产精品岛国久久久久| 国产精品美女久久久久AV福利| 无码人妻少妇久久中文字幕| 无码人妻久久一区二区三区免费 | 亚洲国产精品久久久久网站| 久久久久国色AV免费看图片| 精品久久久无码人妻中文字幕| 久久精品国产亚洲AV嫖农村妇女 | 亚洲午夜久久影院| 成人久久免费网站| 精品久久久久国产免费| 亚洲va中文字幕无码久久不卡| 免费精品99久久国产综合精品| 久久久中文字幕日本| 国产精品岛国久久久久| 性做久久久久久久久久久| 国产精品青草久久久久婷婷| 久久久久久国产a免费观看黄色大片| 国产综合久久久久| 伊人久久大香线蕉综合影院首页 | 亚洲精品乱码久久久久久不卡| 青青草原1769久久免费播放| 欧美激情一区二区久久久|