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

我希望你是我獨家記憶

一段永遠封存的記憶,隨風而去
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| 欧美一区二区成人| 欧美精彩视频一区二区三区| 亚洲大胆美女视频| 免费一区视频| 欧美日产国产成人免费图片| 99视频在线观看一区三区| 日韩天堂av| 国产精品综合| 欧美91福利在线观看| 欧美国产日本| 欧美一区午夜精品| 久久久久久97三级| 亚洲美女福利视频网站| 99视频一区二区| 国产综合久久久久久鬼色| 美国成人直播| 欧美视频中文在线看| 久久久久**毛片大全| 欧美激情四色 | 在线看片日韩| 日韩视频在线观看免费| 国产精品一区二区你懂的| 你懂的成人av| 国产精品国产三级国产普通话99 | 久久亚洲捆绑美女| 中文日韩电影网站| 久久久噜噜噜久久中文字免| 日韩午夜免费视频| 久久久精品动漫| 亚洲免费人成在线视频观看| 久久久久久久久一区二区| 在线视频日韩精品| 久久久久一本一区二区青青蜜月| 夜夜夜久久久| 卡一卡二国产精品| 欧美亚洲日本网站| 欧美日一区二区三区在线观看国产免| 午夜欧美不卡精品aaaaa| 欧美日韩国产在线看| 亚洲一区中文字幕在线观看| 久久亚洲电影| 久久久www免费人成黑人精品| 欧美日本亚洲视频| 欧美激情一区二区三区成人| 国内外成人在线| 亚洲深夜av| 亚洲网站视频| 欧美精品一区二区三区在线播放| 久久久久久69| 国产亚洲精品aa午夜观看| 一区二区三区欧美亚洲| 99视频一区二区三区| 欧美成人福利视频| 欧美1区2区| 最新国产精品拍自在线播放| 欧美在线一区二区| 欧美一区二区免费视频| 国产精品久久久久久户外露出| 亚洲乱码一区二区| 一区二区黄色| 国产精品观看| 亚洲视频中文| 欧美一乱一性一交一视频| 国产精品国产一区二区| 99精品国产在热久久| 在线中文字幕一区| 欧美午夜视频在线观看| 一本综合精品| 午夜综合激情| 国产一区 二区 三区一级| 久久不射2019中文字幕| 久久深夜福利免费观看| 国内伊人久久久久久网站视频| 欧美在线播放| 美女国产一区| 亚洲人www| 国产精品盗摄久久久| 亚洲欧美成人网| 久久亚洲精选| 日韩视频免费在线| 国产精品va在线播放我和闺蜜| 亚洲宅男天堂在线观看无病毒| 性欧美办公室18xxxxhd| 国产在线播放一区二区三区| 老色鬼精品视频在线观看播放| 欧美激情视频给我| 亚洲午夜一区| 国产视频久久久久久久| 久久免费视频在线观看| 亚洲国产专区| 亚洲深夜福利视频| 国产精品一区=区| 久久在线免费视频| 99精品视频免费观看视频| 欧美在线观看视频| 最新中文字幕亚洲| 国产精品美女久久久久久免费| 校园激情久久| 亚洲精品乱码| 久久精品综合网| 99视频超级精品| 国产麻豆日韩| 欧美激情精品久久久久久黑人| 亚洲一区二区三区午夜| 欧美成人精品| 性视频1819p久久| 亚洲精品一区二区三区99| 国产精品视频yy9099| 欧美久久久久| 精品999日本| 欧美午夜剧场| 免费日韩av片| 亚洲欧美在线网| 亚洲精品在线免费观看视频| 久久乐国产精品| 亚洲一区二区精品在线观看| 亚洲电影免费观看高清完整版在线观看 | 亚洲国产美女| 国内精品模特av私拍在线观看| 欧美日韩成人综合在线一区二区 | 亚洲国产成人精品久久| 欧美在线精品免播放器视频| 亚洲精品日韩激情在线电影| 国产精品极品美女粉嫩高清在线| 久久国产福利| 欧美亚洲日本一区| 亚洲综合日韩| 中文欧美日韩| 亚洲精品免费观看| 欧美黄色视屏| 久久综合九色九九| 久久久久久婷| 久久久国产精品一区二区中文| aaa亚洲精品一二三区| 精品福利免费观看| 国产精品一区免费视频| 欧美成人综合在线| 久久久久久自在自线| 亚洲女人av| 日韩一区二区久久| 亚洲麻豆视频| 一本色道久久| 亚洲精品日本| 欧美二区在线看| 欧美制服丝袜| 久久成人在线| 久久精品日韩欧美| 久久精品视频一| 久久久久成人精品| 噜噜噜在线观看免费视频日韩| 久久资源av| 免费不卡在线观看| 另类尿喷潮videofree| 久久精品在线观看| 欧美一区二区三区视频在线 | 国产综合欧美| 国产一区二区三区四区三区四| 国产精品美女久久久久av超清| 欧美日韩国产欧| 欧美日韩亚洲系列| 欧美日韩精品免费在线观看视频| 欧美日韩精品在线播放| 蜜桃av综合| 欧美日韩1区2区3区| 欧美日韩另类字幕中文| 国产精品国产一区二区| 国产精品综合色区在线观看| 国产日韩av一区二区| 国产亚洲精品bv在线观看| 尤物99国产成人精品视频| 韩国精品一区二区三区| 亚洲国产va精品久久久不卡综合| 日韩视频永久免费| 亚洲性线免费观看视频成熟| 亚洲图片在区色| 久久精品99无色码中文字幕| 欧美.www| 日韩视频三区| 中文一区在线| 久久国产成人| 国产在线一区二区三区四区| 精品成人在线观看| 中文亚洲视频在线| 欧美aa在线视频| 亚洲性图久久| 欧美国产丝袜视频| 国产无一区二区| 一区二区精品在线| 麻豆精品视频在线观看视频| 亚洲精品综合精品自拍| 久久精品免费看| 国产精品人人做人人爽| 99热免费精品| 欧美成在线视频| 久久成人综合网| 国产九区一区在线| 亚洲主播在线播放| 欧美激情一区二区三区成人| 亚洲欧美日韩一区二区三区在线|