• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0
            先求任意兩點(diǎn)之間不經(jīng)過城堡的最短路。d[i][j]表示到達(dá)i點(diǎn)使用了j次鞋子的最短路長(zhǎng)度。
            以下是我的代碼:
            #include <queue>
            #include 
            <algorithm>
            #include 
            <cstdio>
            #include 
            <cstring>
            using namespace std;

            const int kMaxn = 107;
            const int kMaxm = kMaxn * kMaxn;
            const int kInf = 0x7f7f7f7f;

            int A, B, M, L, K, g[kMaxn][kMaxn];
            int d[kMaxn][17];
            bool inq[kMaxn][17];

            struct State {
                State ( 
            const int &_u, const int &_k ) : u ( _u ), k ( _k ) { }
                
            int u, k;
            };

            void Input () {
                memset ( g, 
            0x7fsizeof ( g ) );
                scanf ( 
            "%d%d%d%d%d"&A, &B, &M, &L, &K );
                
            while ( M-- ) {
                    
            int u, v, w;
                    scanf ( 
            "%d%d%d"&u, &v, &w );
                    g[u][v] 
            = g[v][u] = w;
                }
            }

            void Solve () {
                
            for ( int k = 1; k <= A; k++ )
                    
            for ( int i = 1; i <= A+B; i++ )
                        
            for ( int j = 1; j <= A+B; j++ )
                            
            if ( g[i][k] < kInf && g[k][j] < kInf && g[i][j] > g[i][k] + g[k][j] )
                                g[i][j] 
            = g[i][k] + g[k][j];
                
                queue
            <State> q;
                memset ( d, 
            0x7fsizeof ( d ) );
                memset ( inq, 
            falsesizeof ( inq ) );
                d[A
            +B][0= 0;
                q.push ( State ( A
            +B, 0 ) );
                
            while ( !q.empty() ) {
                    
            int u = q.front().u, k = q.front().k;
                    q.pop(); inq[u][k] 
            = false;
                    
            for ( int v = 1; v <= A + B; v++ ) {
                        
            if ( k < K && g[u][v] <= L ) {
                            
            if ( d[v][k+1> d[u][k] ) {
                                d[v][k
            +1= d[u][k];
                                
            if ( !inq[v][k+1] ) {
                                    q.push ( State ( v, k
            +1 ) );
                                    inq[v][k
            +1= true;
                                }
                            }
                            
            if ( d[v][k] > d[u][k] + g[u][v] ) {
                                d[v][k] 
            = d[u][k] + g[u][v];
                                
            if ( !inq[v][k] ) {
                                    q.push ( State ( v, k ) );
                                    inq[v][k] 
            = true;
                                }
                            }
                        }
                        
            else {
                            
            if ( d[v][k] > d[u][k] + g[u][v] ) {
                                d[v][k] 
            = d[u][k] + g[u][v];
                                
            if ( !inq[v][k] ) {
                                    q.push ( State ( v, k ) );
                                    inq[v][k] 
            = true;
                                }
                            }
                        }
                    }
                }
                
            int ans = kInf;
                
            for ( int i = 0; i <= K; i++ )
                    ans 
            = min ( ans, d[1][i] );
                printf ( 
            "%d\n", ans );
            }

            int main () {
            #ifndef ONLINE_JUDGE
                freopen ( 
            "data.in""r", stdin );
            #endif
                
            int T;
                scanf ( 
            "%d"&T );
                
            while ( T-- ) {
                    Input ();
                    Solve ();
                }
                
            return 0;
            }

            posted on 2011-11-04 09:25 lee1r 閱讀(983) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 題目分類:圖論
            av无码久久久久久不卡网站| 午夜精品久久久久久影视777| 欧美日韩久久中文字幕| 久久久久久精品免费看SSS | 亚洲国产精品无码久久久久久曰 | 香蕉久久夜色精品升级完成| 久久久久亚洲精品无码蜜桃 | 久久精品中文字幕大胸| 国产成人久久精品激情| 亚洲欧美日韩精品久久亚洲区 | 伊人久久综合无码成人网| 7777久久亚洲中文字幕| 尹人香蕉久久99天天拍| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久乐国产精品亚洲综合| 日韩精品久久久肉伦网站 | 91久久精品国产91性色也| 精品久久久久久久国产潘金莲 | 伊人色综合久久天天网 | 久久精品国产99国产精品亚洲 | 99re久久精品国产首页2020| 精品久久久久久久久免费影院 | 色婷婷综合久久久久中文字幕| 亚洲精品国产字幕久久不卡| 欧美性大战久久久久久| 热99re久久国超精品首页| 99久久久国产精品免费无卡顿 | 久久久久人妻一区精品| 久久久国产精品福利免费| 欧美精品久久久久久久自慰| 久久久久人妻一区二区三区| 久久夜色精品国产www| 蜜臀久久99精品久久久久久| 精品国产热久久久福利| 国产综合精品久久亚洲| 品成人欧美大片久久国产欧美...| 色综合久久中文综合网| 7国产欧美日韩综合天堂中文久久久久 | 久久人人爽人人爽人人片av麻烦| 亚洲国产天堂久久综合| 亚洲欧美一区二区三区久久|