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

pku 3635

2009年8月1日

題目鏈接:PKU 3635 Full Tank ?
  
題目分類:一道有趣的bfs(有點難度)

題目分析與算法原型

         題目大意是,給你n個城市(n最大可以到1000)以及每個城市對應的油價,這些城市間有m條路徑及每條路徑對應的所連接的兩個城市以及路徑的長度(每條路徑連接兩個城市)也告訴了你,給你一輛車,車的油箱儲備量也已知,最后給你剛才n個城市中的某兩個a和b,問你用給你的汽車從a能不能到達b,若能,怎么走才能使得你所花費的油錢最小(路徑每走一單位需要用1升油),并輸出這個最小的花費..........
        老實說,從看到這道題目開始的將近一整天時間里面我都沒有什么好的思路,知道是一道廣搜,但是還不是特別清楚買油的方式,最后參考了某位大牛前輩的思路,才有了一點眉目(哎,搜索太爛了,有待提高啊)。大致做法是定義一個數組dis[][],其中dis[i][j]代表汽車到達i號城市,且油箱里面還有j升油的時候的最小花費,創建一個最小堆維護(不用堆優化鐵定超時,剛開始堆優化沒寫好,貢獻了2次TLE),從隊列中取出最小花費的那個,然后以它作為節點擴展開來(注意,這道題目城市數比較大,采用鄰接表存儲比較好)..........
        
        具體做法如下:
 1.每次從隊列中彈出第一個元素,因為采用了最小堆維護,這樣可以確保彈出的元素一定是隊列中花費最小那個元素

 2. 假設彈出的元素對應的是dij[C][L](既是在C號城市,剩下L升汽油時的最小花費)然后我們每次只買一升油,此時所花費的錢算上剛才一共是dij[C][L]+price[C](price[C]代表C號城市的油價),然后更新,取dij[C][L+1]=Min(dij[C][L+1],dij[C][L]+price[C]),新擴展的元素入隊列

3.枚舉每個和C號城市相互鄰接的城市X,如果當前儲備的油L>=d(d為C到X的路徑長度),說明可以開到X城市,此時油剩下L-d,然后更新,取dis[X][L-d]=Min(dis[X][L-d],dis[C][L]),相應的元素入隊列.


Code:

  1
#include<stdio.h>
  2#define INF 1000000000
  3#define len 1005
  4int map[len][len],price[len],cost[len][len],n,m,count;
  5int dis[len][105],flag[len][105];
  6struct node
  7{
  8    int city,fuel,money;
  9}
queue[1000000];
 10void down_min_heap(int n,int h)//n表示堆元素的個數,從0開始編號,從h開始往下調整
 11{
 12    int i=h,j=2*i+1;
 13    node temp=queue[i];
 14    while(j<n)
 15    {
 16        if(j<n-1&&queue[j].money>queue[j+1].money)j++;//若右孩子存在,且右孩子比較小,取右
 17        if(temp.money<queue[j].money)break;
 18        else
 19        {
 20            queue[i]=queue[j];
 21            i=j;
 22            j=2*i+1;
 23        }

 24    }

 25    queue[i]=temp;
 26}

 27void up_min_heap(int s)
 28{
 29    while (s>0&&queue[s].money<queue[(s-1)/2].money)     //從s開始往上調整
 30    
 31        node tt=queue[s];
 32        queue[s]=queue[(s-1)/2];
 33        queue[(s-1)/2]=tt;
 34        s = (s-1)/2
 35    }

 36}

 37node pop()
 38{
 39    node res=queue[0];
 40    queue[0]=queue[count-1];
 41    count--;
 42    down_min_heap(count,0);
 43    return res;
 44}

 45void push(int c,int f,int m)
 46{
 47    queue[count].city=c;
 48    queue[count].fuel=f;
 49    queue[count].money=m;
 50    count++;
 51    up_min_heap(count-1);
 52}

 53int bfs(int cap,int start,int end)
 54{
 55    int i,j;
 56    count =0;
 57    for(i=0;i<n;i++)
 58        for(j=0;j<=cap;j++)
 59            dis[i][j]=INF,flag[i][j]=0;
 60    
 61    push(start,0,0);
 62    dis[start][0= 0
 63
 64    while (count>0)
 65    {
 66        node u=pop();
 67        int city=u.city,left=u.fuel;
 68        if (flag[city][left]) continue
 69        if (city==end) break
 70        if (left<cap && dis[city][left+1]>dis[city][left]+price[city])
 71        
 72            dis[city][left+1]=dis[city][left]+price[city]; 
 73            push(city, left+1, dis[city][left+1]); 
 74        }

 75        for (i=1; i<= map[city][0];i++
 76        
 77            int v=map[city][i], nc=cost[city][i]; 
 78            if (left>=nc && dis[v][left-nc]>dis[city][left])
 79            
 80                dis[v][left-nc]=dis[city][left]; 
 81                push(v,left-nc,dis[v][left-nc]); 
 82            }

 83        }

 84        flag[city][left] = 1
 85    }

 86    return dis[end][0]; 
 87}

 88int main()
 89{
 90    int i,q;
 91    while(scanf("%d%d",&n,&m)!=EOF)
 92    {
 93        for(i=0;i<n;i++)
 94        {
 95            scanf("%d",&price[i]);
 96            map[i][0]=0;
 97        }

 98        for(i=0;i<m;i++)             //采用鄰接表的方式存
 99        {
100            int a,b,l;
101            scanf("%d%d%d",&a,&b,&l);
102            map[a][++map[a][0]]=b;
103            cost[a][map[a][0]]=l;
104            map[b][++map[b][0]]=a;
105            cost[b][map[b][0]]=l;
106        }

107        scanf("%d",&q);
108        for(i=0;i<q;i++)
109        {
110            int cap,start,end;
111            scanf("%d%d%d",&cap,&start,&end);
112            int res=bfs(cap,start,end);
113            if(res<INF)printf("%d\n",res);
114            else printf("impossible\n");
115        }

116    }

117    return 1;
118}

119

posted on 2009-08-01 16:02 蝸牛也Coding 閱讀(1599) 評論(2)  編輯 收藏 引用

評論

# re: pku 3635 2009-08-01 16:12 Vincent

=.=最短路徑吧...O(n^2)?  回復  更多評論   

# re: pku 3635 2009-08-04 17:25 付翔

不錯   回復  更多評論   


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2009年7月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

導航

統計

常用鏈接

留言簿(8)

隨筆檔案(78)

搜索

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产日韩欧美二区| 亚洲国产精品尤物yw在线观看| 亚洲电影毛片| 奶水喷射视频一区| 久久综合图片| 亚洲精品资源美女情侣酒店| 欧美成人午夜剧场免费观看| 欧美aⅴ一区二区三区视频| 亚洲国产99精品国自产| 亚洲国产视频直播| 欧美日韩精品中文字幕| 中文欧美在线视频| 亚洲一区在线直播| 国产综合精品| 最新国产拍偷乱拍精品| 国产精品高潮呻吟久久av无限| 性做久久久久久久免费看| 欧美一区日本一区韩国一区| 精品福利电影| 最新亚洲视频| 国产亚洲毛片| 亚洲经典三级| 国产亚洲精品aa午夜观看| 久久久久久久久久久久久9999 | 中日韩美女免费视频网址在线观看| 91久久精品国产91久久性色| 欧美日韩一区二区欧美激情 | 雨宫琴音一区二区在线| 亚洲成色777777女色窝| 亚洲深夜福利网站| 亚洲自拍偷拍福利| 亚洲韩日在线| 欧美一区二区三区的| 亚洲黑丝在线| 午夜精品久久久久久久| 亚洲日本欧美在线| 欧美在线|欧美| 日韩一区二区免费看| 久久av在线看| 亚洲一区二区在线| 麻豆精品91| 久久精品国产成人| 欧美日韩免费观看一区| 欧美成人tv| 国产日韩欧美一二三区| 亚洲免费电影在线| 亚洲激情黄色| 久久精品一本| 欧美一区二区三区免费观看视频| 久久资源在线| 看片网站欧美日韩| 国产精品羞羞答答| 99re6热只有精品免费观看| 红桃视频一区| 欧美综合77777色婷婷| 亚洲一区日本| 欧美小视频在线观看| 亚洲第一二三四五区| 在线成人av.com| 性色av一区二区三区| 午夜精品999| 国产精品久久激情| 亚洲一区二区日本| 亚洲欧美bt| 国产精品久久77777| 99re66热这里只有精品3直播| 亚洲日本欧美在线| 欧美成人精品| 亚洲国产精品第一区二区| 亚洲二区在线视频| 久久男人资源视频| 美女网站久久| 亚洲国产小视频在线观看| 久久裸体艺术| 欧美电影在线观看| 日韩视频一区二区三区在线播放免费观看| 久久综合亚州| 亚洲国产专区校园欧美| 亚洲精选视频免费看| 欧美精品黄色| 一本久久a久久精品亚洲| 亚洲性视频h| 国产精品女主播| 小黄鸭精品aⅴ导航网站入口| 欧美尤物巨大精品爽| 狠狠爱成人网| 蜜桃久久av一区| 亚洲精品国产精品乱码不99 | 伊人色综合久久天天五月婷| 久久久久在线观看| 亚洲日韩中文字幕在线播放| 99视频一区二区三区| 国产精品欧美久久| 久久精品人人做人人爽电影蜜月| 乱码第一页成人| 亚洲免费观看| 国产精品爽爽爽| 久久全国免费视频| av成人天堂| 女女同性精品视频| 一区二区三区久久久| 国产日韩精品一区二区浪潮av| 久久久免费精品| 亚洲四色影视在线观看| 老司机午夜精品| 亚洲一区二区三区在线观看视频 | 女女同性精品视频| 中文在线不卡| 欧美v国产在线一区二区三区| 99精品国产福利在线观看免费| 国产精品爱久久久久久久| 久久九九免费视频| 亚洲天堂免费观看| 欧美激情在线| 久久xxxx| 正在播放日韩| 在线观看日韩一区| 国产欧美日韩精品一区| 欧美激情二区三区| 久久人91精品久久久久久不卡| 在线视频亚洲| 亚洲精品美女| 免费的成人av| 久久久久久9| 欧美一区二区三区婷婷月色 | 欧美一区二区三区成人| 亚洲伦理在线免费看| 国产午夜亚洲精品羞羞网站| 欧美日韩国产综合视频在线观看中文| 久久成人精品| 欧美在线二区| 亚洲午夜一区| 亚洲一二三级电影| 99视频在线观看一区三区| 欧美成人亚洲成人日韩成人| 欧美专区在线| 欧美亚洲免费| 欧美一级午夜免费电影| 亚洲视频香蕉人妖| aa日韩免费精品视频一| 亚洲国产成人精品女人久久久 | 欧美黄色影院| 免费观看日韩| 欧美成黄导航| 欧美大片一区二区| 欧美大片免费观看在线观看网站推荐| 久久久久久久一区| 久久久人人人| 久久性天堂网| 久热精品视频在线观看一区| 久久九九精品| 久久亚洲不卡| 欧美国产第二页| 亚洲黄一区二区| 亚洲精品欧美| 亚洲视频观看| 午夜精品一区二区在线观看| 亚洲综合视频一区| 欧美制服丝袜第一页| 欧美一区二区视频在线观看| 欧美在线日韩在线| 快播亚洲色图| 欧美日本高清一区| 国产精品国产三级国产aⅴ9色| 欧美午夜一区二区| 国产精品自在在线| 国内精品一区二区三区| 亚洲黄色成人| 亚洲欧美韩国| 久久综合一区二区| 亚洲精华国产欧美| 亚洲一级影院| 美女黄毛**国产精品啪啪| 欧美日韩国产精品一区二区亚洲| 国产精品蜜臀在线观看| 影音先锋日韩有码| 亚洲天堂av在线免费| 久久精品国产久精国产思思| 欧美高清视频一二三区| 一本色道久久综合亚洲精品婷婷| 午夜视频精品| 欧美日韩黄色一区二区| 国产一区二区三区无遮挡| 亚洲精品三级| 久久国产精品网站| 亚洲全部视频| 欧美一区二区免费| 欧美日韩成人在线观看| 国内精品一区二区| 在线视频欧美日韩| 另类酷文…触手系列精品集v1小说| 欧美大香线蕉线伊人久久国产精品| 欧美电影免费观看大全| 午夜精品美女久久久久av福利| 久久精品一区二区三区中文字幕| 老司机午夜精品视频在线观看| 国产精品视频yy9099| 亚洲国产合集| 亚洲尤物在线视频观看| 亚洲激情视频网|