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

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>
            国产精品成人午夜| 一个人看的www久久| 欧美一区在线直播| 亚洲一区在线免费观看| 一区二区三区欧美亚洲| 亚洲一区999| 亚洲一区二区不卡免费| 午夜精品视频在线观看一区二区| 亚洲在线中文字幕| 欧美一区二区三区四区在线| 久久精品网址| 欧美激情在线狂野欧美精品| 欧美日韩精品是欧美日韩精品| 欧美日一区二区在线观看 | 中文国产亚洲喷潮| 亚洲男人av电影| 久久久999精品免费| 欧美人与禽性xxxxx杂性| 国产精品人人做人人爽| 激情五月综合色婷婷一区二区| 99re热这里只有精品免费视频| 国产精品99久久久久久有的能看| 欧美在线播放高清精品| 欧美www视频在线观看| 亚洲精品久久久久久下一站 | 亚洲一区二区三区777| 欧美一区二区在线播放| 亚洲国产另类精品专区| 欧美在线高清视频| 欧美揉bbbbb揉bbbbb| 在线观看亚洲精品| 亚洲综合色在线| 亚洲国产导航| 久久精品理论片| 国产精品久久999| 亚洲经典在线| 米奇777在线欧美播放| 亚洲视频电影图片偷拍一区| 老司机亚洲精品| 国产精品一页| 亚洲一区尤物| 亚洲另类一区二区| 女人香蕉久久**毛片精品| 国产日韩欧美一区二区| 亚洲香蕉伊综合在人在线视看| 欧美二区乱c少妇| 久久精品国产精品亚洲| 国产午夜精品在线| 国产精品视频1区| 9i看片成人免费高清| 欧美成人精品1314www| 欧美在线欧美在线| 国产精品永久入口久久久| 亚洲手机视频| 99热精品在线观看| 欧美韩日亚洲| 亚洲精品视频免费观看| 亚洲国产精彩中文乱码av在线播放| 久久精品国产99精品国产亚洲性色 | 亚洲永久在线观看| 欧美 日韩 国产 一区| 欧美在线免费观看| 狠狠爱成人网| 蜜乳av另类精品一区二区| 亚洲欧美日韩国产中文| 国产精品麻豆va在线播放| 亚洲一区二区三区影院| 亚洲素人在线| 国产日韩欧美综合在线| 久久亚洲私人国产精品va| 久久久精品999| 亚洲大片av| 欧美www在线| 欧美精品日韩www.p站| 一区二区三区你懂的| 亚洲视频高清| 在线欧美一区| 99视频+国产日韩欧美| 国产精品婷婷午夜在线观看| 久久精品国产综合| 玖玖玖免费嫩草在线影院一区| 亚洲久久在线| 亚洲一区二区三区乱码aⅴ蜜桃女| 国产女主播在线一区二区| 久久婷婷人人澡人人喊人人爽| 免费视频一区| 午夜精品久久久久久| 欧美自拍偷拍午夜视频| 亚洲区一区二| 亚洲一区二区三区精品在线观看| 一区免费在线| 99精品视频网| 亚洲第一在线综合在线| 日韩一区二区免费看| 国产亚洲精品v| 亚洲高清在线观看| 国产亚洲激情在线| 亚洲精品网站在线播放gif| 国产麻豆午夜三级精品| 欧美激情在线免费观看| 国产精品一区二区三区乱码| 欧美www视频在线观看| 国产精品免费一区二区三区在线观看| 久久中文精品| 国产精品视频yy9099| 欧美国产丝袜视频| 亚洲欧美经典视频| 在线亚洲免费| 免费中文日韩| 久久国产精品一区二区| 欧美日本高清| 欧美电影免费观看| 国产日韩欧美麻豆| 99国产精品视频免费观看| 亚洲高清不卡在线| 先锋影音久久久| 亚洲免费在线视频| 欧美精品一区在线发布| 欧美大片专区| 影音先锋久久| 欧美在线一二三四区| 亚洲欧美视频| 欧美亚洲第一页| 亚洲精品一区二区三区樱花| 亚洲精品看片| 免费不卡亚洲欧美| 免费成人美女女| 国产在线播放一区二区三区| 亚洲一区日韩在线| 亚洲免费中文| 国产精品久久97| 亚洲一级电影| 欧美一级久久| 国产欧美高清| 欧美在线视屏 | 亚洲人成艺术| 亚洲美洲欧洲综合国产一区| 欧美不卡激情三级在线观看| 欧美国产视频日韩| 亚洲国产一区在线| 欧美成人精品一区| 亚洲欧洲日本专区| 亚洲精品影视| 欧美午夜激情视频| 国产一区二区三区丝袜| 亚洲欧美综合另类中字| 久久精品欧美日韩精品| 海角社区69精品视频| 久久综合给合久久狠狠狠97色69| 欧美99在线视频观看| 亚洲肉体裸体xxxx137| 欧美激情网友自拍| 在线亚洲+欧美+日本专区| 亚洲欧美综合精品久久成人| 国产亚洲va综合人人澡精品| 欧美在线视频网站| 亚洲高清视频一区| 亚洲欧美制服另类日韩| 国产亚洲制服色| 老**午夜毛片一区二区三区| 亚洲美女av在线播放| 久久国产一区二区三区| 亚洲国产精品久久久久婷婷884 | 欧美成人综合一区| 洋洋av久久久久久久一区| 欧美性视频网站| 欧美在线免费看| 日韩一区二区免费看| 卡一卡二国产精品| 国产精品视频网址| 久久久久国产精品厨房| 亚洲精品激情| 麻豆精品精品国产自在97香蕉| 日韩视频在线观看免费| 国产日韩在线不卡| 蜜臀va亚洲va欧美va天堂| 亚洲影视中文字幕| 女人色偷偷aa久久天堂| 亚洲男人影院| 亚洲精品午夜| 国产综合色产在线精品| 欧美视频免费在线| 美女精品在线观看| 欧美在线日韩在线| 亚洲影院污污.| 亚洲欧洲在线看| 欧美日韩综合另类| 欧美成人免费网站| 久久国产88| 亚洲性感激情| 亚洲国产一区二区精品专区| 国产精品永久入口久久久| 欧美日韩成人一区二区| 久久久久久久久一区二区| 亚洲天堂av在线免费| 亚洲二区免费| 免费观看日韩av| 久久久欧美一区二区| 性欧美videos另类喷潮| 宅男噜噜噜66一区二区66|