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

pku 3635

2009年8月1日

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

題目分析與算法原型

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

 2. 假設(shè)彈出的元素對應(yīng)的是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]),相應(yīng)的元素入隊列.


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表示堆元素的個數(shù),從0開始編號,從h開始往下調(diào)整
 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開始往上調(diào)整
 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 閱讀(1593) 評論(2)  編輯 收藏 引用

評論

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

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

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

不錯   回復(fù)  更多評論   


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


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

導(dǎo)航

統(tǒng)計

常用鏈接

留言簿(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>
            av成人免费在线观看| 日韩亚洲一区二区| 国产精品综合不卡av| 国产精品视频网址| 国产亚洲成av人在线观看导航 | 亚洲一区二区三区免费观看 | 快播亚洲色图| 伊人久久噜噜噜躁狠狠躁| 暖暖成人免费视频| 国产精品国产三级国产aⅴ浪潮| 国产一级久久| 亚洲一区二区日本| 日韩午夜三级在线| 老司机午夜精品视频| 国产欧美va欧美va香蕉在| 一区二区在线观看视频在线观看 | 一区二区三区四区蜜桃| 久久久亚洲高清| 欧美啪啪成人vr| 亚洲免费激情| 麻豆freexxxx性91精品| 午夜日韩福利| 一区二区高清视频| 欧美午夜精品一区| 亚洲美女诱惑| 亚洲第一精品夜夜躁人人爽| 久久夜色精品国产噜噜av| 国产性做久久久久久| 亚洲欧美在线高清| 一本色道久久综合亚洲精品高清 | 欧美一区观看| 一本大道久久a久久综合婷婷| 欧美成人69| 亚洲素人在线| 中文久久精品| 国产精品日韩欧美一区| 亚洲精品免费观看| 一本久道久久综合中文字幕| 欧美日韩免费观看一区三区| 一区二区三区欧美激情| 久久免费精品日本久久中文字幕| 美女日韩欧美| 亚洲精品一区在线观看| 亚洲日本va午夜在线影院| 国产精品任我爽爆在线播放| 欧美一区二视频在线免费观看| 亚洲主播在线观看| 国产精品专区h在线观看| 牛牛影视久久网| 欧美高清日韩| 亚洲一区二区三区精品在线| 一区二区国产日产| 亚洲成色www久久网站| 欧美电影专区| 欧美久久一级| 午夜伦理片一区| 免费成人在线观看视频| 亚洲丝袜av一区| 午夜久久影院| 国产无一区二区| 蜜臀av性久久久久蜜臀aⅴ| 蜜臀av一级做a爰片久久| 亚洲欧美另类久久久精品2019| 午夜精品国产更新| 牛人盗摄一区二区三区视频| 欧美精品亚洲精品| 亚洲在线观看| 亚洲视频欧美视频| 亚洲国产岛国毛片在线| 亚洲日本欧美日韩高观看| 国产精品久久999| 亚洲欧美另类在线| 欧美日韩国产精品一区| 欧美主播一区二区三区美女 久久精品人 | 欧美激情视频在线播放| 欧美日韩播放| 久久se精品一区精品二区| 一区二区三区四区国产精品| 亚洲精品久久久久久久久| 亚洲欧美清纯在线制服| 91久久精品国产| 亚洲国产女人aaa毛片在线| 国内精品久久久久久久影视麻豆 | 亚洲欧美精品伊人久久| 亚洲一区区二区| 美女视频黄 久久| 欧美一区成人| 欧美日韩福利| 91久久久一线二线三线品牌| 国产亚洲一区在线| 99国产精品久久久久久久久久 | 亚洲国产91色在线| 亚洲电影在线播放| 午夜精品久久久久久久男人的天堂 | 麻豆国产精品一区二区三区| 久久综合狠狠综合久久激情| 国模私拍一区二区三区| 欧美在线免费观看| 裸体女人亚洲精品一区| 亚洲国产精品一区二区第一页| 老司机精品视频网站| 欧美国产日韩视频| 日韩视频在线你懂得| 欧美日韩hd| 亚洲自拍偷拍福利| 久久影音先锋| 亚洲欧洲精品一区| 欧美日韩在线精品| 一本久久a久久免费精品不卡| 欧美日韩综合久久| 亚洲国产精品一区二区www| 亚洲国产精品999| 欧美国产视频一区二区| 99riav国产精品| 欧美在线视频全部完| 黄色亚洲大片免费在线观看| 免费观看日韩| 亚洲视频一起| 久久久综合香蕉尹人综合网| 亚洲福利小视频| 欧美午夜理伦三级在线观看| 午夜在线成人av| 欧美国产综合一区二区| 一区二区国产精品| 国产视频一区在线观看| 免费一级欧美片在线观看| 一区二区三区欧美视频| 久久久精品性| 99精品国产一区二区青青牛奶| 国产精品久久二区二区| 久久久久久久999精品视频| 亚洲精品日韩激情在线电影| 久久精品亚洲一区二区| 99re66热这里只有精品3直播 | 一区二区不卡在线视频 午夜欧美不卡'| 欧美日韩色婷婷| 久久九九精品99国产精品| 日韩午夜免费| 免费成人性网站| 亚洲欧美国产高清va在线播| 亚洲成在人线av| 国产免费一区二区三区香蕉精| 欧美va亚洲va香蕉在线| 亚洲欧美国产77777| 最新国产精品拍自在线播放| 久久久噜噜噜久久狠狠50岁| 亚洲午夜精品国产| 亚洲黄色av一区| 国产亚洲福利一区| 国产精品久久影院| 欧美日韩国产三区| 噜噜噜在线观看免费视频日韩| 亚洲免费中文字幕| 99视频一区二区三区| 欧美刺激性大交免费视频| 欧美在线日韩精品| 亚洲性感激情| 一区二区欧美国产| 亚洲精品之草原avav久久| 伊人精品在线| 国产啪精品视频| 国产精品美女久久久久久2018| 欧美日本韩国一区| 欧美国产日韩一区| 欧美.日韩.国产.一区.二区| 久久婷婷蜜乳一本欲蜜臀| 欧美亚洲综合在线| 亚洲欧美区自拍先锋| 亚洲一区二区三区成人在线视频精品| 91久久精品美女高潮| 亚洲电影在线看| 亚洲高清视频一区二区| 欧美激情1区2区3区| 欧美福利视频| 亚洲第一页在线| 欧美激情中文字幕在线| 欧美成人中文| 欧美激情亚洲视频| 亚洲第一综合天堂另类专| 欧美黄色一区二区| 亚洲激情小视频| 亚洲精品一区二区在线观看| 亚洲精品一区二区在线| 午夜激情综合网| 亚洲国产精品成人综合| 在线观看欧美亚洲| 亚洲国产精品尤物yw在线观看| 在线成人小视频| 亚洲激情视频网| 99日韩精品| 亚洲影视九九影院在线观看| 亚洲欧美综合另类中字| 欧美中文在线字幕| 美女精品网站| 亚洲国产黄色| 制服诱惑一区二区| 久久国产主播精品| 欧美极品在线观看| 国产精品国产成人国产三级| 国产一区二区三区四区三区四|