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

我希望你是我獨家記憶

一段永遠封存的記憶,隨風而去
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>
            欧美成人dvd在线视频| 久久一本综合频道| 亚洲欧美激情视频在线观看一区二区三区| 久久久久久999| 狂野欧美一区| 亚洲欧洲久久| 欧美午夜无遮挡| 欧美在线1区| 亚洲高清在线观看一区| 久久国产日本精品| 欧美成人精品| 一区二区三区日韩| 国产亚洲激情视频在线| 欧美激情亚洲视频| 性视频1819p久久| 亚洲精品少妇30p| 久久久久国产成人精品亚洲午夜| 亚洲国产精品一区二区尤物区| 欧美成人一品| 免费在线观看一区二区| 国产精品福利在线观看| 男女精品网站| 欧美成人一区在线| 欧美国产在线观看| 久久久五月婷婷| 欧美国产乱视频| 国产精品美女主播| 欧美激情视频一区二区三区不卡| 欧美精品亚洲精品| 欧美视频一区二区三区…| 欧美一区网站| 在线亚洲免费视频| 亚洲精选一区二区| 亚洲免费视频成人| 亚洲在线免费| 日韩亚洲国产欧美| 亚洲国产精品嫩草影院| 男女视频一区二区| 亚洲美女精品久久| 欧美一区二区视频免费观看| 欧美高清你懂得| 国产日本欧美一区二区三区| 国产精品嫩草久久久久| 一色屋精品亚洲香蕉网站| 狠狠网亚洲精品| 国产一区二区三区四区三区四| 亚洲国产精品v| 久久精品成人| 美女视频黄免费的久久| 久久婷婷国产综合尤物精品| 9久草视频在线视频精品| 国产一区二区三区奇米久涩| 国内精品视频666| 国产在线日韩| 中文精品视频一区二区在线观看| 一区二区三区视频在线观看 | 国产真实久久| 亚洲婷婷综合色高清在线| 麻豆久久婷婷| 久久久视频精品| 国产在线精品二区| 久久精品人人做人人爽电影蜜月| 亚洲午夜久久久久久久久电影院| 在线亚洲一区二区| 欧美国产亚洲另类动漫| 在线精品一区| 亚洲视频1区2区| 亚洲黄一区二区| 亚洲影院一区| 国产精品区一区二区三区| 国产午夜精品一区理论片飘花| 精品成人国产| 亚洲视频高清| 中文高清一区| 国产精品日韩精品| 亚洲主播在线播放| 欧美暴力喷水在线| 久久国产毛片| 亚洲激情国产| 久久免费黄色| 99精品热视频只有精品10| 欧美中文在线字幕| 激情成人亚洲| 亚洲人成啪啪网站| 久久青青草原一区二区| 国产精品ⅴa在线观看h| 亚洲欧美一区二区三区久久| 亚洲第一综合天堂另类专| 美女久久一区| 黄色在线成人| 亚洲激情成人在线| 国产精品久久久久久久7电影 | 这里只有精品丝袜| 国产亚洲福利一区| 亚洲欧洲精品一区二区精品久久久| 欧美色另类天堂2015| 久久久九九九九| 欧美激情1区2区3区| 午夜激情一区| 欧美国产精品日韩| 久久精品国产一区二区三区免费看| 久久亚洲图片| 香港久久久电影| 一区二区不卡在线视频 午夜欧美不卡在 | 男女激情久久| 亚洲欧美一区二区激情| 久久精品99无色码中文字幕| 亚洲国产色一区| 亚洲小说欧美另类社区| 亚洲国产片色| 欧美怡红院视频一区二区三区| 亚洲看片网站| 蜜桃av综合| 欧美日韩在线高清| 一区二区电影免费观看| 欧美一二三区在线观看| 欧美一区二区在线观看| 日韩视频一区二区| 久久五月天婷婷| 久久se精品一区二区| 欧美在线免费观看| 亚洲国产99| 国产精品欧美日韩久久| 亚洲福利av| 精东粉嫩av免费一区二区三区| 一本久道综合久久精品| 亚洲精品系列| 亚洲高清免费| 韩国成人福利片在线播放| 在线中文字幕日韩| 一区二区高清视频| 免费日韩一区二区| 另类欧美日韩国产在线| 国产日韩精品电影| 亚洲欧美日韩一区二区| 精品av久久707| 亚洲免费视频成人| 午夜在线精品偷拍| 夜夜嗨av一区二区三区| 91久久国产自产拍夜夜嗨| 久久九九全国免费精品观看| 亚洲日韩成人| 久久影视三级福利片| 亚洲午夜激情| 亚洲欧美日韩精品久久久久| 亚洲一区二区免费看| aa成人免费视频| 亚洲精品国产系列| 欧美国产日韩一二三区| 亚洲激情在线观看视频免费| 亚洲精品久久| 欧美日韩精品免费看| 夜夜嗨av一区二区三区中文字幕| 亚洲国产美女久久久久| 欧美日韩一区二区视频在线观看 | 国产精品色婷婷| 一本色道久久综合亚洲91| 亚洲一级在线观看| 国产精品嫩草99a| 伊人久久大香线蕉综合热线| 性色av一区二区三区红粉影视| 久久精品一二三区| 在线观看国产成人av片| 久久亚洲一区二区| 亚洲精品国产精品国自产观看浪潮| 免费成人在线观看视频| 欧美激情在线播放| 国产精品一区在线播放| 欧美成人免费大片| 亚洲国产一区二区三区在线播| 国产专区欧美专区| 久久综合给合| 亚洲国产91| 欧美日韩免费在线观看| 亚洲一区欧美一区| 精品1区2区3区4区| 噜噜噜久久亚洲精品国产品小说| 亚洲国产99| 午夜精品久久久99热福利| 国内外成人免费视频| 欧美屁股在线| 欧美激情一区二区| 亚洲一区成人| 欧美波霸影院| 久久黄色级2电影| 一本一本a久久| 亚洲一区二区在线观看视频| 久久久久www| 国产精品少妇自拍| 六月天综合网| 亚洲欧美激情一区二区| 亚洲国产一区二区三区在线播| 欧美日韩一区二区欧美激情| 欧美一区二区免费| 日韩午夜免费视频| 欧美激情一区二区三区| 久久久激情视频| 亚洲一区二区欧美日韩| 香蕉尹人综合在线观看| 9l视频自拍蝌蚪9l视频成人|