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

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>
            91久久久久久久久久久久久| 蜜臀av在线播放一区二区三区| 亚洲一区在线直播| 99精品欧美一区| 一区二区三区国产精品| 夜夜嗨av一区二区三区四季av| 91久久精品美女| 中文精品视频| 久久久999| 亚洲国产激情| 亚洲美女网站| 欧美一级播放| 欧美国产先锋| 欧美午夜精品久久久久久超碰| 国产精品va在线播放| 国产午夜精品全部视频播放| 亚洲电影下载| 亚洲欧美一区在线| 久久综合久久综合这里只有精品| 欧美肥婆bbw| 亚洲一级电影| 久久综合精品国产一区二区三区| 欧美日韩国产123| 国产伦精品一区二区三区| 亚洲国产91| 亚洲欧美日韩在线| 亚洲高清色综合| 亚洲欧美激情视频在线观看一区二区三区| 久久av一区二区三区漫画| 欧美激情va永久在线播放| 国产日韩欧美| 亚洲小视频在线| 欧美激情久久久久| 欧美在线免费观看视频| 欧美日韩视频一区二区三区| 韩国精品在线观看| 亚洲欧美三级在线| 亚洲国产片色| 久久亚洲视频| 国产日韩欧美91| 亚洲欧美国产不卡| 亚洲卡通欧美制服中文| 久久久久久久一区| 国产亚洲精品成人av久久ww| 亚洲综合色激情五月| 最新日韩在线| 久久天天躁狠狠躁夜夜爽蜜月| 国产精品揄拍一区二区| 一级日韩一区在线观看| 亚洲电影第1页| 久久欧美肥婆一二区| 国产伪娘ts一区| 欧美一区二区在线看| 一本久久知道综合久久| 欧美日韩视频专区在线播放 | 国产欧美日本| av成人手机在线| 欧美高清在线视频| 久久久久久色| 在线视频国产日韩| 久久综合国产精品| 久久爱www.| 国产亚洲精品久久久久动| 午夜伦理片一区| 亚洲一区二区三区高清不卡| 欧美私人网站| 亚洲一区二区在线免费观看| 99精品国产在热久久婷婷| 欧美极品色图| 99这里只有精品| 最近中文字幕日韩精品| 欧美精品大片| 亚洲一区二区视频在线观看| 亚洲欧洲视频| 欧美小视频在线| 欧美在线观看你懂的| 性欧美xxxx大乳国产app| 国产午夜精品在线| 久久夜色精品国产欧美乱极品| 欧美亚洲视频在线观看| 韩国成人精品a∨在线观看| 欧美a级在线| 欧美精品一卡二卡| 亚洲欧美日本精品| 久久久99免费视频| 日韩午夜精品| 亚洲自拍另类| 亚洲经典一区| 亚洲午夜在线观看视频在线| 国语自产精品视频在线看| 欧美激情女人20p| 国产精品福利在线观看| 久久网站热最新地址| 欧美精品一区视频| 欧美在线91| 欧美成人免费网| 亚洲欧美在线aaa| 欧美自拍偷拍午夜视频| 99这里有精品| 久久精品亚洲国产奇米99| 亚洲精品在线观看免费| 亚洲综合日本| 亚洲精选在线观看| 午夜在线观看欧美| 亚洲精品少妇网址| 羞羞色国产精品| 一本综合精品| 久久欧美肥婆一二区| 亚洲欧美激情一区| 欧美高清在线精品一区| 久久人体大胆视频| 欧美日韩精品系列| 欧美freesex交免费视频| 国产精品久久久久永久免费观看 | 亚洲视频在线观看视频| 老司机一区二区| 欧美视频在线免费看| 免费欧美日韩国产三级电影| 国产精品家庭影院| 亚洲欧洲日本专区| 91久久视频| 久久九九免费视频| 欧美一站二站| 国产精品久久国产精品99gif| 亚洲国产欧美在线| 91久久精品美女高潮| 久久婷婷丁香| 久久一区二区三区超碰国产精品| 国产精品一区二区三区观看| 一区二区毛片| 亚洲影院免费| 国产精品九九久久久久久久| 夜夜嗨av一区二区三区免费区 | 香蕉免费一区二区三区在线观看| 欧美成人在线免费视频| 欧美激情91| 亚洲欧洲精品一区| 免费观看日韩av| 欧美大香线蕉线伊人久久国产精品| 国产一区二区高清视频| 欧美中文在线视频| 久久久青草青青国产亚洲免观| 国产农村妇女毛片精品久久麻豆| 正在播放欧美一区| 亚洲欧美制服中文字幕| 国产精品国产精品| 亚洲视频第一页| 午夜精品亚洲一区二区三区嫩草| 欧美性做爰猛烈叫床潮| 在线午夜精品自拍| 欧美亚洲在线播放| 国外成人网址| 欧美成人免费全部| 亚洲国产日韩欧美| 亚洲午夜免费视频| 国产精品亚洲综合色区韩国| 久久激五月天综合精品| 欧美激情第五页| 亚洲一区3d动漫同人无遮挡| 国产欧美婷婷中文| 玖玖综合伊人| 一本不卡影院| 久久精品亚洲一区二区| 伊人久久亚洲热| 欧美大尺度在线观看| 一本久久综合亚洲鲁鲁| 久久精品二区| 亚洲精品欧美| 国产精品一区二区欧美| 久久影视精品| 在线一区二区视频| 久久久亚洲一区| 日韩视频精品| 国产日韩欧美电影在线观看| 久久久久一区二区| 亚洲毛片在线观看| 久久综合网络一区二区| 夜夜躁日日躁狠狠久久88av| 国产视频丨精品|在线观看| 狂野欧美激情性xxxx| 一区二区三区黄色| 欧美a级片一区| 亚洲淫性视频| 欧美在线观看日本一区| 麻豆精品网站| 在线免费观看视频一区| 欧美小视频在线| 美女尤物久久精品| 亚洲欧美国产不卡| 亚洲人在线视频| 久久久噜噜噜久久人人看| 一本一本久久| 亚洲国产电影| 国产在线播放一区二区三区| 欧美色视频一区| 欧美xxx成人| 欧美中文字幕视频在线观看| 日韩视频一区二区| 亚洲电影免费| 免费观看欧美在线视频的网站|