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

我希望你是我獨家記憶

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

P1511

Posted on 2008-09-05 19:28 Hero 閱讀(189) 評論(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>
            国模 一区 二区 三区| 亚洲国产91精品在线观看| 欧美日韩国产一区精品一区| 免费中文字幕日韩欧美| 欧美三级在线视频| 国产日韩专区| 亚洲精品黄色| 午夜精品久久久久久久蜜桃app| 欧美自拍偷拍| 亚洲欧洲精品天堂一级| 亚洲愉拍自拍另类高清精品| 久久久国产精彩视频美女艺术照福利| 狂野欧美激情性xxxx欧美| 欧美午夜视频| 亚洲精品视频啊美女在线直播| 亚洲国产一区二区在线| 欧美一区二区播放| 欧美精品久久一区二区| 国产综合欧美在线看| 欧美成人精品在线| 亚洲欧美电影院| 欧美精品18+| 午夜在线视频观看日韩17c| 亚洲黄色毛片| 国产欧美丝祙| 午夜精品一区二区三区在线播放| 午夜一区二区三区在线观看| 国产精品久久久久秋霞鲁丝| 亚洲精品网站在线播放gif| 一区二区三区国产在线| 欧美激情bt| 日韩一级视频免费观看在线| 另类图片国产| 久久精品日韩| 亚洲在线一区| 一本色道88久久加勒比精品 | 久久久久久久久久久一区| 99在线热播精品免费99热| 欧美精品久久一区| 久久夜色精品国产噜噜av| 欧美一区在线视频| 一区二区三区自拍| 久久一区亚洲| 国产毛片一区二区| 欧美一区观看| 久久国产精品久久久久久久久久| 国产麻豆9l精品三级站| 亚洲破处大片| 欧美色网一区二区| 欧美成人中文| 欧美激情日韩| 亚洲第一精品电影| 黄色成人在线网站| 欧美成人精品在线| 国产亚洲人成网站在线观看| 麻豆成人91精品二区三区| 国产精品久久久久一区二区| 亚洲激情欧美| 亚洲精品中文字幕在线观看| 一本色道久久| 日韩亚洲欧美一区| 欧美国产精品一区| 欧美国产激情二区三区| 在线看片成人| 亚洲最新合集| 一区二区三区国产精品| 亚洲欧美偷拍卡通变态| 亚洲国产99| 一本大道av伊人久久综合| 亚洲免费观看| 欧美激情亚洲精品| 亚洲人成网站777色婷婷| 日韩天堂在线观看| 欧美日本在线视频| 久久精品二区三区| 欧美激情在线免费观看| 亚洲黄色在线观看| 夜色激情一区二区| 欧美专区中文字幕| 玖玖国产精品视频| 91久久综合| 亚洲欧美卡通另类91av | 国产婷婷97碰碰久久人人蜜臀| 亚洲在线1234| 久久亚洲不卡| 亚洲精品国产精品国自产观看 | 99亚洲精品| 欧美亚洲一区二区在线观看| 国产一区二区中文字幕免费看| 欧美在线日韩| 亚洲国产视频一区| 亚洲字幕一区二区| 国产在线精品自拍| 欧美成人免费va影院高清| 久久国产日韩| 亚洲人成人一区二区三区| 欧美另类久久久品| 亚洲欧美日韩中文视频| 女仆av观看一区| 在线一区亚洲| 在线成人黄色| 久久久夜夜夜| 久久综合九色综合久99| 99热免费精品| 国产一区二区在线免费观看 | 欧美精品一区三区| 亚洲在线观看免费| 欧美国产一区二区| 伊人久久成人| 欧美午夜精品久久久久久久| 欧美主播一区二区三区美女 久久精品人| 嫩草国产精品入口| 亚洲欧美怡红院| 亚洲人久久久| 国产亚洲欧美一区二区三区| 欧美日韩不卡视频| 久久精品国产第一区二区三区最新章节| 亚洲国产精品久久| 老牛国产精品一区的观看方式| 亚洲色图自拍| 国产精品v欧美精品v日韩| 久久久久久网| 香蕉免费一区二区三区在线观看| 亚洲欧洲日韩在线| 欧美大片在线看免费观看| 欧美一二三区精品| 亚洲一区二区日本| 亚洲影视在线播放| 亚洲二区精品| 一本色道**综合亚洲精品蜜桃冫| 国产自产2019最新不卡| 国产精品久久久久999| 亚洲最黄网站| 亚洲国产精品毛片| 麻豆免费精品视频| 久久久久久久久久久久久久一区 | 亚洲卡通欧美制服中文| 国产一区免费视频| 国产欧美日韩专区发布| 国产精品免费在线| 国产精品国产一区二区| 欧美私人网站| 国产精品成人免费视频 | 欧美激情亚洲国产| 欧美国产第二页| 欧美电影免费观看高清完整版| 久久一区二区三区四区五区| 亚洲欧洲综合另类在线| 亚洲国产你懂的| 亚洲高清在线视频| 亚洲激情视频在线播放| 亚洲人成在线观看| 99综合在线| 亚洲综合另类| 欧美有码在线视频| 久久精品视频免费观看| 久久人人爽人人爽| 麻豆久久精品| 亚洲综合精品四区| 欧美一区日韩一区| 久久精品在线视频| 欧美不卡视频| 欧美日韩黄色大片| 国产欧美日韩三级| 在线成人小视频| 亚洲精品一区久久久久久| 亚洲深夜福利网站| 欧美一区激情| 欧美大片18| 在线亚洲欧美视频| 亚洲第一在线综合网站| 亚洲激情自拍| 亚洲综合二区| 久久视频精品在线| 欧美日韩亚洲不卡| 你懂的亚洲视频| 欧美体内谢she精2性欧美| 国产一区二区中文字幕免费看| 亚洲二区视频| 亚洲男女自偷自拍| 亚洲视频在线观看免费| 欧美在线播放一区| 亚洲成在线观看| 乱中年女人伦av一区二区| 亚洲人成网站精品片在线观看| 亚洲男人的天堂在线| 久久一区视频| 国产精品色在线| 国产精品美女一区二区在线观看| 国内外成人在线| 中日韩美女免费视频网址在线观看| 欧美伊人久久久久久久久影院| 亚洲第一在线综合在线| 亚洲自拍三区| 欧美女同在线视频| 1000部精品久久久久久久久| 午夜欧美大尺度福利影院在线看| 欧美电影在线播放| 欧美中在线观看| 国产精品丝袜白浆摸在线|