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

我希望你是我獨家記憶

一段永遠封存的記憶,隨風而去
posts - 263, comments - 31, trackbacks - 0, articles - 3
   :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

P1511

Posted on 2008-09-05 19:28 Hero 閱讀(183) 評論(0)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM
  1 //1511 Accepted 196124K 4141MS C++ 4292B PKU
  2 
  3 //堆優化的鄰接鏈表形式的最短路徑
  4 //注意Heap_Dijkstra( 1, 0 )而不是(1, inn)
  5 
  6 #include <stdio.h>
  7 #include <stdlib.h>
  8 #include <string.h>
  9 
 10 
 11 const int size = 1010010 ;
 12 const long long INF = 10000000000000 ;
 13 
 14 struct NODE
 15 {
 16     int num ;
 17     long long len ;
 18     struct NODE *next ;
 19 
 20     //NODE() { len = INF ; next = NULL ; }
 21 };
 22 //struct NODE head[size*90] ;
 23 struct NODE head1[size*10] ;
 24 struct NODE head2[size*10] ;
 25 int chead ;
 26 
 27 struct EDGE
 28 {
 29     int sn ; int en ; long long len ; int toheap ;
 30 };
 31 struct EDGE dist1[size] ;
 32 struct EDGE dist2[size] ;
 33 //typedef struct EDGE EDGE ;
 34 
 35 int flag[size] ;
 36 int heap[size] ; int numh ;
 37 
 38 int inn, inm ; int innum ;
 39 long long out ;
 40 
 41 void input()
 42 {
 43     forint i=0; i<=inn; i++ ) head1[i].next = head2[i].next = NULL ;
 44 
 45     int sn, en, len ; chead = inn + 10 ; struct NODE *temp ;
 46     forint i=1; i<=inm; i++ )
 47     {
 48         scanf( "%d %d %d"&sn, &en, &len ) ;
 49         //data[i][0] = sn ; data[i][1] = en ; data[i][2] = len ;
 50         //temp = (struct NODE *)malloc( sizeof(NODE) ) ;
 51         //struct NODE *temp = new NODE ;
 52         temp = &head1[chead++] ;
 53         temp->len = len ; temp->num = en ;
 54         temp->next = head1[sn].next ; head1[sn].next = temp ;
 55 
 56         //temp = (struct NODE *)malloc( sizeof(NODE) ) ;
 57         temp = &head2[chead++] ;
 58         temp->len = len ; temp->num = sn ;
 59         temp->next = head2[en].next ; head2[en].next = temp ;
 60     }
 61 }
 62 
 63 void swap( int &a, int &b )
 64 {
 65     int t = a ; a = b ; b = t ;
 66 }
 67 
 68 void moveup( EDGE *arry, int n )
 69 {//將新加入的節點向上移動來維持堆,n表示要向上移動的點的坐標
 70     //while( n && arry[n] > arry[(n-1)>>1] )//大頂堆
 71     while( n&&arry[heap[n]].len<arry[heap[(n-1)/2]].len )//小頂堆
 72     {
 73         swap( arry[heap[n]].toheap, arry[heap[(n-1)/2]].toheap ) ;
 74         swap( heap[n], heap[(n-1)/2] ) ;
 75         n = (n-1/ 2 ;
 76     }
 77 }
 78 
 79 void movedown( EDGE *arry, int n )
 80 {//堆頂改變后,將其向下移動維持堆,n表示堆中元素總數目
 81     int i = 0 ;
 82     while( i+i+1 < n )
 83     {
 84         //if( i+i+2<n&&arry[i+i+2]>arry[i+i+1]&&arry[i+i+2]>arry[i] )
 85         if( i+i+2<n&&arry[heap[i+i+2]].len<arry[heap[i+i+1]].len&&arry[heap[i+i+2]].len<arry[heap[i]].len )
 86         {
 87             swap( arry[heap[i+i+2]].toheap, arry[heap[i]].toheap ) ;
 88             swap( heap[i+i+2], heap[i] ) ;
 89             i = i + i + 2 ;
 90         }
 91         //else if( arry[i+i+1] > arry[i] )
 92         else if( arry[heap[i+i+1]].len < arry[heap[i]].len )
 93         {
 94             swap( arry[heap[i+i+1]].toheap, arry[heap[i]].toheap ) ;
 95             swap( heap[i+i+1], heap[i] ) ; 
 96             i = i + i + 1 ;
 97         }
 98         else break ;
 99     }
100 
101 }
102 
103 void Heap_Dijkstra( EDGE dist[], NODE head[], int sn, int en )
104 {
105     numh = -1 ; struct NODE * p ;
106     forint i=1; i<=inn; i++ )
107     {
108         if( i == sn )
109         {
110             flag[i] = 1 ; //pren[i] = -1 ;
111             dist[i].sn = sn ; dist[i].en = sn ; dist[i].len = 0 ;
112             heap[++numh] = i ; dist[i].toheap = numh ; moveup( dist, numh ) ;
113         }
114         else
115         {
116             flag[i] = 0 ; //pren[i] = sn ;
117             dist[i].sn = sn ; dist[i].en = i ;
118             //for( p=head[sn].next; p!=NULL&&p->num!=i; p=p->next ) ;
119             //if( NULL == p )    dist[i].len = INF ; else dist[i].len = p->len ;
120             dist[i].len = INF ;
121             heap[++numh] = i ; dist[i].toheap = numh ; moveup( dist, numh ) ;
122         }
123     }//init
124     forint ct=1; ct<=inn; ct++ )
125     {
126         if( numh < 0 )    break ;
127         int next = dist[heap[0]].en ; if( dist[next].len >= INF )    break ;
128         if( next == en )    return ;
129         swap( dist[heap[0]].toheap, dist[heap[numh]].toheap ) ;
130         swap( heap[0], heap[numh] ) ; numh-- ; movedown( dist, numh+1 ) ;
131         flag[next] = 1 ; int curn ; 
132         for( p=head[next].next; p; p=p->next )
133         {
134             curn = p->num ;
135             if0==flag[curn]&&p->len<INF&&dist[next].len+p->len<dist[curn].len )
136             {
137                 dist[curn].len = dist[next].len + p->len ; //pren[curn] = next ;
138                 moveup( dist, dist[curn].toheap ) ;
139             }
140         }
141     }
142 }
143 
144 void process()
145 {
146     out = 0 ;
147 
148     Heap_Dijkstra( dist1, head1, 10 ) ;
149     forint i=1; i<=inn; i++ ) out += dist1[i].len ;
150 
151     Heap_Dijkstra( dist2, head2, 10 ) ; 
152     forint i=1; i<=inn; i++ ) out += dist2[i].len ;
153 }
154 
155 void output()
156 {
157     printf( "%lld\n"out ) ;
158 }
159 
160 int main()
161 {
162     //freopen( "in.txt", "r", stdin ) ;
163     //freopen( "out.txt", "w", stdout ) ;
164 
165     //while( scanf( "%d", &innum ) != EOF )
166     scanf( "%d"&innum ) ;
167     {
168         forint ct=1; ct<=innum; ct++ )
169         {
170             scanf( "%d %d",&inn, &inm ) ;
171 
172                 input() ;
173 
174                 process() ;
175 
176                 output() ;
177         }
178     }
179 
180     return 0 ;
181 }
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久黄色网页| 国产麻豆一精品一av一免费| 亚洲高清自拍| 久久久噜久噜久久综合| 欧美在线视频导航| 欧美专区第一页| 久久精品中文| 久久综合电影| 男人插女人欧美| 亚洲国产精品久久| 亚洲美女91| 亚洲一区二区在线看| 午夜视频一区在线观看| 久久精品国产视频| 嫩草国产精品入口| 欧美日韩国产美女| 国产日韩av高清| 有坂深雪在线一区| 亚洲国产精品女人久久久| 亚洲精品美女在线| 西瓜成人精品人成网站| 久久综合影音| 亚洲精品国精品久久99热| 亚洲一区二区三区精品在线观看| 香蕉乱码成人久久天堂爱免费| 久久久91精品国产一区二区精品| 欧美国产成人精品| 国产乱码精品一区二区三| 亚洲第一区在线观看| 亚洲调教视频在线观看| 久久亚洲一区| 亚洲视频免费观看| 欧美精品v国产精品v日韩精品| 国产欧美精品在线| 亚洲国产精品日韩| 国内视频一区| 亚洲网在线观看| 美女主播视频一区| 亚洲尤物影院| 欧美日韩视频| 亚洲缚视频在线观看| 香蕉尹人综合在线观看| 亚洲欧洲一区二区在线播放| 国产亚洲一区在线| 美女精品网站| 久久色在线播放| 亚洲一区二区精品在线观看| 久久婷婷人人澡人人喊人人爽 | 最新国产成人av网站网址麻豆 | 精品福利免费观看| 中文日韩在线| 久久这里只有| 亚洲永久字幕| 欧美日韩你懂的| 久久疯狂做爰流白浆xx| 亚洲靠逼com| 国产精品久久久久久久久免费樱桃| 亚洲婷婷在线| 欧美一区二区三区喷汁尤物| 亚洲在线国产日韩欧美| 久久久天天操| 日韩午夜三级在线| 国产美女精品一区二区三区| 在线日韩电影| 欧美高清免费| 久久亚洲综合| 欧美日韩免费在线视频| 亚洲性图久久| 国产精品99久久久久久www| 欧美午夜一区| 亚洲在线免费| 噜噜噜91成人网| 夜色激情一区二区| 欧美国产精品v| 久久久亚洲国产天美传媒修理工 | 国产亚洲一区二区在线观看 | 亚洲图片在区色| 亚洲精品小视频| 欧美日韩在线精品一区二区三区| 日韩午夜av电影| 99在线精品视频在线观看| 国产精品大片| 久久久伊人欧美| 欧美v国产在线一区二区三区| 亚洲国产一区二区三区青草影视 | 99精品视频免费| 日韩香蕉视频| 国产精品久久久久久福利一牛影视| 亚洲综合久久久久| 午夜在线视频一区二区区别 | 亚洲午夜精品国产| 宅男噜噜噜66国产日韩在线观看| 国产精品一区久久久| 久久一区二区三区四区| 欧美大片一区二区| 亚洲欧美综合v| 免费黄网站欧美| 亚洲欧美日韩中文视频| 久久免费视频这里只有精品| 夜夜嗨av一区二区三区中文字幕 | 久久久xxx| 一区二区av在线| 欧美在线视频日韩| 999在线观看精品免费不卡网站| 亚洲图色在线| 亚洲人成在线播放网站岛国| 在线综合视频| 亚洲国产三级在线| 午夜伦理片一区| 一本久久综合亚洲鲁鲁| 欧美一区二区三区精品电影| 一区二区三区四区五区精品| 久久狠狠一本精品综合网| 亚洲视频一二三| 牛牛影视久久网| 久久天堂国产精品| 欧美国产精品va在线观看| 亚洲一区国产| 亚洲精品乱码久久久久久黑人| 亚洲一区二区欧美| 制服诱惑一区二区| 欧美成人高清| 欧美91大片| 国产自产在线视频一区| 亚洲亚洲精品在线观看 | 亚洲人成网站在线观看播放| 欧美在线免费一级片| 香蕉免费一区二区三区在线观看| 欧美电影免费| 欧美韩国日本一区| 在线成人黄色| 欧美专区在线观看一区| 久久av一区二区| 国产精品一区在线观看| 一区二区欧美国产| 一区二区欧美在线观看| 欧美激情在线观看| 亚洲国产综合在线看不卡| 在线看欧美视频| 久久久久久久波多野高潮日日| 欧美在线一级va免费观看| 国产精品久久精品日日| 在线亚洲免费| 午夜精品久久久99热福利| 国产精品毛片一区二区三区| 亚洲午夜久久久| 久久激情五月激情| 国产伦一区二区三区色一情| 亚洲欧美日韩国产中文在线| 久久av免费一区| 在线观看一区视频| 欧美国产先锋| 一区二区三区四区国产精品| 亚洲天堂av在线免费观看| 国产精品久久久久一区二区三区共| 亚洲欧美另类综合偷拍| 久久免费视频网| 亚洲精品日韩久久| 国产精品久久国产精品99gif| 羞羞答答国产精品www一本| 美女久久一区| 夜夜精品视频一区二区| 国产精品久久久久久久久免费樱桃 | 91久久精品国产91性色tv| 欧美国产三区| 亚洲特色特黄| 久久野战av| 亚洲视频999| 国产在线精品自拍| 免费久久久一本精品久久区| 日韩视频在线播放| 久久蜜桃精品| 一本色道久久| 国产在线精品二区| 欧美日本高清视频| 久久国产一区二区| 日韩午夜高潮| 欧美gay视频激情| 亚洲图片欧洲图片日韩av| 国产亚洲人成网站在线观看| 欧美精品七区| 久久精品一区二区三区中文字幕| 亚洲人成欧美中文字幕| 亚洲人线精品午夜| 亚洲尤物在线| 欧美韩日一区| 久久狠狠一本精品综合网| 亚洲精品在线看| 国产一区二区成人久久免费影院| 欧美国产日韩精品| 久久久av网站| 欧美亚洲视频| 亚洲深夜av| 亚洲国产欧美日韩精品| 久久久久久网址| 香蕉久久夜色| 亚洲一区二三| 亚洲一级黄色av| 99视频在线精品国自产拍免费观看| 国产一区日韩欧美|