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

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋

題目地址:
         http://acm.hdu.edu.cn/showproblem.php?pid=2066
題目描述:
一個人的旅行
Time Limit: 
1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 
4077    Accepted Submission(s): 1348


Problem Description
雖然草兒是個路癡(就是在杭電待了一年多,居然還會在校園里迷路的人,汗
~),但是草兒仍然很喜歡旅行,因為在旅途中 會遇見很多人(白馬王子,^0^),很多事,還能豐富自己的閱歷,還可以看美麗的風景……草兒想去很多地方,她想要去東京鐵塔看夜景,去威尼斯看電影,去陽明山上看海芋,去紐約純粹看雪景,去巴黎喝咖啡寫信,去北京探望孟姜女……眼看寒假就快到了,這么一大段時間,可不能浪費啊,一定要給自己好好的放個假,可是也不能荒廢了訓練啊,所以草兒決定在要在最短的時間去一個自己想去的地方!因為草兒的家在一個小鎮上,沒有火車經過,所以她只能去鄰近的城市坐火車(好可憐啊~)。
 

Input
輸入數據有多組,每組的第一行是三個整數T,S和D,表示有T條路,和草兒家相鄰的城市的有S個,草兒想去的地方有D個;
接著有T行,每行有三個整數a,b,time,表示a,b城市之間的車程是time小時;(
1=<(a,b)<=1000;a,b 之間可能有多條路)
接著的第T
+1行有S個數,表示和草兒家相連的城市;
接著的第T
+2行有D個數,表示草兒想去地方。
 

Output
輸出草兒能去某個喜歡的城市的最短時間。
 

Sample Input
6 2 3
1 3 5
1 4 7
2 8 12
3 8 4
4 9 12
9 10 2
1 2
8 9 10
 

Sample Output
9

題目分析:
        剛開始做的時候也沒做分析, 直接就是枚舉每個起點到每個終點的 最短距離, 然后取最短的路,  很顯然, TLE.................
還是自己沒有把DIJKSTRA 算法理解好.... 再次看了一遍算法的描述和數據結構書上的 sample后 發現, 其實算法執行過程中
已經把起點到其他點的最短距離全部算出來了, 所以只需要 枚舉每個起點就可以了, 興奮之下, 馬上修改了代碼, Submit! ......
很 杯具, 還是tle ...... 不明白為什么.....看網上其他人寫的 解題報告 , 原來很多人也是這做的, 枚舉起始點, 但是他們的卻可以AC.
雖然時間一般是 100MS左右. 這里我一直很糾結, 不明白同樣的算法為什么我的會TLE.    
         在 AMB 大牛的提示下, 不需要全部枚舉, 只要把所有起點的距離都設置成0就可以了,  但是不知道為什么, 還是一直TLE.

最后的辦法是:   設置一個起點指向所有起點, 之間的距離設置為 1, 同樣 設置一個終點指向所有終點, 距離同樣設置為1, 最后
使用 DIJKSTRA 算法 求出起點到終點的最短距離 - 2 就行了. 

代碼如下:
#include <iostream>
using namespace std;
const int INF = 0x7FFFFFFF;
int T,S,D,L;
const int MAXN=1005;    //點個數
int graph[MAXN][MAXN];
int s[MAXN];
int d[MAXN];
int Dijkstra ( int beg, int end )
{
    
bool hash[MAXN];
    
int path[MAXN];
    
for ( int i = 0; i <= L; ++ i )
    {
          hash[i] 
= true;
          path[i] 
= INF; 
    } 
    hash[beg] 
= false;
    path[beg] 
= 0;
    
while ( beg != end )
    {
           
for ( int i = 0; i <= L; ++ i )
           {
                 
if ( graph[beg][i] != 0 )
                 {
                      
if ( path[i] > path[beg] + graph[beg][i] ) 
                           path[i] 
= path[beg] + graph[beg][i];
                 } 
           } 
           
int min = INF;
           
for ( int i = 0; i <= L; ++ i )
           {
                 
if ( min > path[i] && hash[i] )
                 {
                      min 
= path[i];
                      beg 
= i; 
                 } 
           }
           hash[beg] 
= false;
    }   
    
return path[end];
}

int main ()

    
while ( scanf ( "%d%d%d",&T,&S,&D ) != EOF )
    {
          memset ( graph , 
0 , sizeof ( graph ) );
          L 
= 0;
          
for ( int i = 1; i <= T; ++ i )
          {
                
int r,c,cost;
                scanf ( 
"%d%d%d",&r,&c,&cost );
                
if ( graph[r][c] == 0 )
                     graph[r][c] 
= graph[c][r] = cost ;
                
else
                {
                     
if ( cost < graph[r][c] ) 
                          graph[r][c] 
= graph[c][r] = cost ;
                }
                
if ( L < max ( r,c ) )
                     L 
= max ( r,c );
          } 
          
for ( int i = 0; i != S; ++ i )
          {
               scanf ( 
"%d",&s[i] );
               graph[
0][ s[i] ] = 1
               graph[ s[i] ][
0= 1;     
          }
          L 
++;
          
for ( int i = 0; i != D; ++ i )
          {
               scanf ( 
"%d",&d[i] );
               graph[ d[i] ][ L ] 
= 1;
               graph[ L ][ d[i] ] 
= 1;
          }
          
          cout 
<< Dijkstra ( 0,L ) - 2 << endl;  
    }
    
return 0



順便 0rz 下大牛 代碼:
#include <iostream>
#define MAX 1005
#define INF 0x7FFF
#define CMP(A,B) (A.d < B.d)
using namespace std;
int d[MAX][MAX];
class HNode {
      
public:
              
int v;
              
int d;
};
class Heap {
public:
        HNode h[MAX 
* 2];
        
int n, p, c;
        Heap() {
                n 
= 0;
        }
        
void inline ins(HNode e) {
                
for (p = ++n; p > 1 && CMP(e,h[p>>1]); h[p] = h[p>>1], p >>= 1)
                        ;
                h[p] 
= e;
        }
        
int inline pop(HNode &e) {
                
if (!n)
                        
return 0;
                
for (e = h[p = 1], c = 2; c < n
                                
&& CMP(h[c += (CMP(h[c + 1],h[c]) && c < n - 1)], h[n]);
                                h[p] 
= h[c], p = c, c <<= 1)
                        ;
                h[p] 
= h[n--];
                
return 1;
        }
};
int Dijkstra(int A, int B, int N) {
        
int dist[MAX];
        
int mask[MAX];
        
int Tmp;
        Heap h;
        HNode e, ne;

        
for (int i = 0; i < N; i++) {
                dist[i] 
= INF;
                mask[i] 
= 0;
        }
        dist[e.v 
= A] = (e.d = 0);
        h.ins(e);
        
while (h.pop(e)) {
                
if (!mask[e.v]) {
                        mask[e.v] 
= 1;
                        
for (int i = 0; i < N; i++) {
                                
if (!mask[i] && (Tmp = e.d + d[e.v][i])
                                                
< dist[i]) {
                                        dist[ne.v 
= i] = (ne.d = Tmp);
                                        h.ins(ne);
                                }
                        }
                }
        }
        
return dist[B];
}
int main() {
        
int T, S, D, M;
        
int st, en, tm;
        
while (scanf("%d %d %d"&T, &S, &D)!=EOF) {
                M 
= 0;
                
for (int i = 0; i < MAX; i++)
                        
for (int j = 0; j < MAX; j++)
                                d[i][j] 
= INF;
                
for (int i = 0; i < T; i++) {
                        scanf(
"%d %d %d"&st, &en, &tm);
                        
if (tm < d[st][en]) {
                                d[st][en] 
= d[en][st] = tm;
                        }

                        M 
= st> M ? st : M;
                        M 
= en> M ? en : M;
                }
                M 
= M + 1;
                
for (int i = 0; i < S; i++) {
                        scanf(
"%d"&st);
                        d[
0][st] = 1;
                        d[st][
0= 1;
                }

                
for (int i = 0; i < D; i++) {
                        scanf(
"%d"&en);
                        d[M][en] 
= 1;
                        d[en][M] 
= 1;
                }
                cout
<<Dijkstra(0, M, M+1)-2<<endl;
        }
        
return 0;
}

Feedback

# re: HDOJ 2066 HDU 2066 一個人的旅行 ACM 2066 IN HDU   回復  更多評論   

2011-03-10 15:36 by Sticktotheend
http://acm.hdu.edu.cn/showproblem.php?pid=3790
你好,看了你的博客,我表示你真的很牛~~~
而且你的代碼不像其它的那些用了很多的模板和容器,看起來舒服很多。關于最短路徑問題,想問你就是杭電3790那道題,你有做過嗎?要是AC了能發給我看看?謝謝啦。我郵箱dmx23344@sina.com
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美国产三区| 激情国产一区| 亚洲韩国一区二区三区| 在线视频日本亚洲性| 蜜桃久久精品一区二区| 久久国产直播| 欧美一区二区三区视频免费| 欧美一级专区免费大片| 欧美自拍偷拍| 欧美成人一区二区三区在线观看| 久久人人爽国产| 久久免费黄色| 亚洲国产精品成人一区二区| 午夜精品福利视频| 亚洲精品欧美日韩专区| 欧美大片在线看免费观看| 欧美成人精品1314www| 欧美国产91| 一本久久综合亚洲鲁鲁五月天| 一区二区高清在线| 久久久精品日韩| 欧美成人免费在线观看| 欧美日韩成人免费| 国产精品av一区二区| 韩国亚洲精品| 一区二区高清| 久久精品国产亚洲一区二区| 欧美成人午夜激情在线| 亚洲精选在线| 午夜精品视频一区| 麻豆精品在线视频| 国产精品视频网站| 亚洲全部视频| 久久九九久精品国产免费直播| 欧美激情中文字幕乱码免费| 一区二区欧美日韩| 久久伊人精品天天| 国产欧美另类| 中文精品视频一区二区在线观看| 久久久精品999| 亚洲婷婷综合色高清在线| 亚洲第一页在线| 性欧美video另类hd性玩具| 欧美福利视频| 在线高清一区| 久久久久九九视频| 亚洲一区二区三区在线| 欧美不卡一卡二卡免费版| 国产亚洲免费的视频看| 亚洲视频在线视频| 亚洲国产精品一区| 久久久久成人精品| 国产欧美一区二区三区在线老狼| 一区二区三区欧美| 亚洲精品美女久久久久| 免费视频一区| 亚洲欧洲免费视频| 裸体一区二区| 久久久久久久精| 黄色成人av在线| 久久网站免费| 久久视频这里只有精品| 国内精品国产成人| 久久久九九九九| 亚洲欧美三级在线| 国产欧美一二三区| 久久精品99| 欧美一区二区三区免费视频| 国产精品视频导航| 久久国产精品久久国产精品| 亚洲天堂第二页| 国产日产亚洲精品| 欧美影院精品一区| 午夜精彩视频在线观看不卡 | 欧美二区在线看| 久久中文字幕一区| 亚洲国产精品一区二区第一页| 嫩草影视亚洲| 欧美成人黄色小视频| 日韩视频永久免费观看| 亚洲日本国产| 国产精品日韩高清| 久久久av水蜜桃| 久久青草欧美一区二区三区| 亚洲人成在线播放| 日韩视频一区二区三区在线播放| 国产精品99一区二区| 久久精品国产综合精品| 久久午夜电影| 亚洲一区二区三区四区五区午夜| 亚洲欧美三级伦理| 最新亚洲激情| 亚洲永久免费视频| 亚洲成人在线免费| 一本色道久久精品| 国产亚洲免费的视频看| 亚洲国产精品成人va在线观看| 欧美系列精品| 欧美大片在线观看| 国产精品中文在线| 亚洲高清av| 国产日本欧美一区二区三区| 欧美成人免费在线视频| 国产精品v日韩精品v欧美精品网站| 久久久国产精品一区二区三区| 欧美成人性生活| 欧美在线观看视频| 欧美激情中文字幕在线| 久久精品成人| 欧美日韩国产在线| 欧美91大片| 国产视频一区在线观看| 亚洲精品无人区| 亚洲国产第一| 久久狠狠久久综合桃花| 亚洲午夜精品| 欧美韩国日本综合| 久久中文字幕导航| 国产精品免费区二区三区观看| 女人香蕉久久**毛片精品| 国产精品激情电影| 91久久中文| 亚洲国产欧美一区二区三区久久 | 欧美偷拍一区二区| 欧美激情一区在线| 亚洲人线精品午夜| 久久综合狠狠综合久久综青草 | 国产精品大全| 久久久噜噜噜久噜久久| 欧美丝袜一区二区| 欧美国产精品专区| 国产精品永久免费在线| 亚洲激情综合| 日韩网站在线| 欧美ed2k| 亚洲国产日韩在线| 亚洲国产精品一区在线观看不卡 | 一区二区av| 亚洲午夜视频在线| 国产精品久久久久av免费| 亚洲精品色婷婷福利天堂| 日韩一级裸体免费视频| 欧美激情一区在线| 亚洲精选视频免费看| 亚洲小视频在线| 国产精品少妇自拍| 亚洲字幕一区二区| 欧美中文字幕在线观看| 国产午夜精品久久久久久免费视 | 久久精品国产在热久久| 国产一二三精品| 免费亚洲一区| 国产精品红桃| a91a精品视频在线观看| 国产免费成人在线视频| 日韩视频免费观看高清完整版| 一区精品久久| 欧美一区二区三区免费观看| 亚洲免费在线观看视频| 国产精品亚发布| 亚洲视频免费在线观看| 亚洲一区二区网站| 欧美激情亚洲国产| 亚洲国产精品va在线观看黑人 | 亚洲国产黄色片| 亚洲高清中文字幕| 免费欧美日韩国产三级电影| 久久尤物电影视频在线观看| 久久九九全国免费精品观看| 久久久噜噜噜久久中文字幕色伊伊 | 国内精品视频在线观看| 亚洲天堂av综合网| 亚洲欧美日韩视频二区| 久久免费黄色| 鲁大师影院一区二区三区| 国产精品综合久久久| 欧美一区二区三区免费观看视频 | 亚洲日本成人在线观看| 在线一区二区日韩| 欧美少妇一区| 99精品国产热久久91蜜凸| 亚洲视频第一页| 国产精品裸体一区二区三区| 日韩网站在线观看| 亚洲一区二区三区精品动漫| 国产日韩一区二区三区在线| 欧美在线影院在线视频| 久久久久久一区| 亚洲第一精品福利| 久久久久久精| 亚洲精品自在久久| 久久爱91午夜羞羞| 亚洲国产精品尤物yw在线观看| 欧美成人xxx| 亚洲专区国产精品| 亚洲国语精品自产拍在线观看| 久久精品中文字幕一区| 中文在线资源观看网站视频免费不卡 | 欧美国产综合| 亚洲欧美另类中文字幕|