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

pku 2908

2009年8月3日

題目鏈接:PKU 2908 Quantum
  
分類:bfs+堆優化

題目分析與算法原型
         這道題總的來說是一個廣度優先搜索,但是需要用最小堆進行優化(如果不用堆,呵呵,我沒試過,不過8成會TLE),每次從隊列中取隊頭元素進行擴展(由于是最小堆,保證了每次取出的元素是當前中花費最小的),需要注意的是,一個已經入過隊列的元素,還可以再入隊列,只要此時他的花費比上次入隊列時小就行,還要注意的一點是結束條件應該是當且隊列彈出的隊頭元素的關鍵值等于目標關鍵值,此時可以結束搜索,因為即使以后再次遇到該關鍵值的元素其花費肯定比現在的大,因為每次從隊頭開始擴展的元素都會比擴展他的父親元素的花費大,我就是這個退出條件沒搞好結果貢獻了n次的WA.............

Code:

  1
#include<stdio.h>
  2#include<string.h>
  3char beg[25],end[25];
  4int n,l,p,w,count,mincost[1200000];
  5bool flag[1200000],finish;
  6struct node
  7{
  8    int cost,num;
  9    char s[25];
 10}
queue[1200000];
 11struct caozuo
 12{
 13    char s[25];
 14    int cost;
 15}
op[35];
 16int cal(char ss[])
 17{
 18    int i,res=0;
 19    for(i=0;i<l;i++)res+=(ss[i]-'0')<<(l-1-i);
 20    return res;
 21}

 22void down_min_heap(int n,int h)//n表示堆元素的個數,從0開始編號,從h開始往下調整
 23{
 24    int i=h,j=2*i+1;
 25    node temp=queue[i];
 26    while(j<n)
 27    {
 28        if(j<n-1&&queue[j].cost>queue[j+1].cost)j++;//若右孩子存在,且右孩子比較小,取右
 29        if(temp.cost<queue[j].cost)break;
 30        else
 31        {
 32            queue[i]=queue[j];
 33            i=j;
 34            j=2*i+1;
 35        }

 36    }

 37    queue[i]=temp;
 38}

 39void up_min_heap(int s)    //s表示最后一個的編號
 40{
 41    while (s>0&&queue[s].cost<queue[(s-1)/2].cost)     //從s開始往上調整
 42    
 43        node tt=queue[s];
 44        queue[s]=queue[(s-1)/2];
 45        queue[(s-1)/2]=tt;
 46        s=(s-1)/2
 47    }

 48}

 49void push(int x,int cost,char s[])
 50{
 51    queue[count].num=x;
 52    queue[count].cost=cost;
 53    strcpy(queue[count].s,s);
 54    count++;
 55    up_min_heap(count-1);
 56}

 57node pop()
 58{
 59    node res=queue[0];
 60    queue[0]=queue[count-1];
 61    count--;
 62    down_min_heap(count,0);
 63    return res;
 64}

 65void handle(int num,node x,int goal,int *ans)
 66{
 67    int i,k;
 68    node y=x;
 69    if(y.num==goal)
 70    {
 71        finish=true;
 72        *ans=y.cost;
 73        return ;
 74    }

 75    for(i=0;i<l;i++)
 76    {
 77        if(op[num].s[i]=='F')
 78        {
 79            if(y.s[i]=='0')y.s[i]='1';
 80            else y.s[i]='0';
 81        }

 82        else if(op[num].s[i]=='S')y.s[i]='1';
 83        else if(op[num].s[i]=='C')y.s[i]='0';
 84    }

 85    k=cal(y.s);
 86    if(!flag[k]||(flag[k]&&op[num].cost+y.cost<mincost[k]))
 87    {
 88        flag[k]=true;
 89        mincost[k]=op[num].cost+y.cost;
 90        push(k,op[num].cost+y.cost,y.s);
 91    }

 92}

 93int bfs(char a[],char b[])
 94{
 95    int r1=cal(a),r2=cal(b),i,ans;
 96    node tt;
 97    queue[0].num=r1;
 98    queue[0].cost=0;
 99    strcpy(queue[0].s,a);
100    count=1;
101    flag[r1]=true;
102    mincost[r1]=0;
103    while(count>0)
104    {
105        tt=pop();
106        for(i=0;i<p&&!finish;i++)handle(i,tt,r2,&ans);
107        if(finish)return ans;
108    }

109    return -1;
110}

111int main()
112{
113    int i;
114    scanf("%d",&n);
115    while(n--)
116    {
117        scanf("%d%d%d",&l,&p,&w);
118        for(i=0;i<p;i++)scanf("%s %d",op[i].s,&op[i].cost);
119        for(i=0;i<w;i++)
120        {
121            scanf("%s %s",beg,end);
122            memset(flag,false,sizeof(flag));
123            finish=false;
124            int res=bfs(beg,end);
125            if(res==-1)printf("NP");
126            else printf("%d",res);
127            if(i<w-1)printf(" ");
128        }

129        printf("\n");
130    }

131    return 1;
132}

133
134
135
136

posted on 2009-08-03 10:32 蝸牛也Coding 閱讀(189) 評論(0)  編輯 收藏 引用

<2009年8月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
303112345

導航

統計

常用鏈接

留言簿(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>
            欧美一区二区精品| 欧美国产日本韩| 欧美日本二区| 亚洲一区二区三区四区五区午夜 | 久久久不卡网国产精品一区| 亚洲小视频在线| 国产日韩精品电影| 久久久久.com| 免费亚洲一区| 中文在线资源观看网站视频免费不卡 | 亚洲欧洲日本国产| 一区二区日韩精品| 国产亚洲一区精品| 亚洲第一区中文99精品| 欧美日韩国产va另类| 香蕉成人啪国产精品视频综合网| 欧美一区二区三区免费在线看 | 国产精品自拍网站| 久久综合伊人| 欧美日韩免费在线| 另类酷文…触手系列精品集v1小说| 玖玖精品视频| 午夜国产精品视频| 麻豆乱码国产一区二区三区| 亚洲主播在线| 久久久亚洲人| 亚洲欧美日韩综合aⅴ视频| 久久精品五月| 亚洲欧美日韩视频二区| 噜噜噜91成人网| 香蕉久久久久久久av网站| 欧美成人午夜激情视频| 久久av一区二区三区| 欧美电影资源| 免费短视频成人日韩| 国产精品视频午夜| 亚洲美女在线视频| 亚洲激情啪啪| 久久国产视频网| 亚洲女同精品视频| 欧美高清视频免费观看| 欧美日韩 国产精品| 亚洲国产精品999| 欧美日韩国产成人高清视频| 老司机午夜精品视频| 国产精品久久午夜夜伦鲁鲁| 亚洲二区视频在线| 国模精品一区二区三区色天香| 一本久久a久久精品亚洲| 91久久中文| 久久免费国产| 美女视频黄 久久| 国内揄拍国内精品少妇国语| 亚洲欧美成人网| 亚洲欧美另类在线| 国产精品久久| 中文在线不卡| 亚洲欧美日韩国产精品| 欧美日韩亚洲一区二区| 亚洲免费大片| 一区二区三区四区五区视频 | 欧美韩日亚洲| 亚洲国产视频直播| 亚洲毛片av| 欧美国产专区| 亚洲最新视频在线播放| 亚洲一区欧美二区| 国产精品稀缺呦系列在线| 亚洲一区二区三区免费视频| 亚洲欧美在线磁力| 国产伦精品一区二区三区高清版 | 日韩视频中文字幕| 欧美日韩激情小视频| 一二三区精品福利视频| 亚洲中午字幕| 国模叶桐国产精品一区| 久久久激情视频| 亚洲高清影视| 亚洲小说欧美另类社区| 国产精品私拍pans大尺度在线| 亚洲午夜电影| 噜噜噜久久亚洲精品国产品小说| 亚洲第一色中文字幕| 欧美华人在线视频| 亚洲视频在线一区| 裸体一区二区| 中国成人在线视频| 国产亚洲精品久| 久久久久久自在自线| 亚洲人精品午夜在线观看| 亚洲欧美在线免费观看| 精品电影一区| 欧美视频日韩视频在线观看| 欧美夜福利tv在线| 亚洲精品日韩在线观看| 久久国产精品高清| 亚洲毛片av| 国产日韩一级二级三级| 欧美成人乱码一区二区三区| 亚洲午夜性刺激影院| 久久只有精品| 亚洲一区成人| 伊人成人网在线看| 国产精品xxxxx| 久久综合电影一区| 亚洲图片欧美一区| 中国女人久久久| 翔田千里一区二区| 91久久精品国产91性色| 久久国产日韩| 亚洲欧美另类中文字幕| 亚洲人成7777| 好吊视频一区二区三区四区| 欧美日韩一级黄| 欧美成年视频| 久久久久国产精品一区二区| 亚洲午夜电影网| 夜夜嗨av一区二区三区中文字幕| 老司机精品视频一区二区三区| 亚洲午夜激情免费视频| 亚洲激情影院| 在线观看欧美黄色| 国产丝袜一区二区三区| 欧美日韩一区二区国产| 欧美jizzhd精品欧美喷水 | 亚洲精品日韩激情在线电影| 久久天天躁夜夜躁狠狠躁2022| 亚洲欧美国产高清va在线播| 日韩视频专区| 9l视频自拍蝌蚪9l视频成人| 娇妻被交换粗又大又硬视频欧美| 国产精品欧美在线| 国产精品久久久久久妇女6080| 欧美精品一区在线| 欧美激情国产精品| 欧美激情精品久久久久久黑人| 久久深夜福利| 老鸭窝毛片一区二区三区| 欧美一区国产在线| 欧美一区二区三区在线免费观看| 亚洲尤物视频网| 欧美亚洲尤物久久| 欧美主播一区二区三区美女 久久精品人| 一区二区三区黄色| 中国女人久久久| 亚洲欧美bt| 久久成人免费视频| 久久一区二区三区超碰国产精品| 久久精品五月婷婷| 嫩草影视亚洲| 欧美精品乱人伦久久久久久| 欧美伦理在线观看| 国产精品久久二区| 国产亚洲精品久久久久动| 免费成人av| 亚洲精品免费在线播放| 99视频在线精品国自产拍免费观看| 中日韩在线视频| 亚洲一区二区少妇| 久久精品国产77777蜜臀| 麻豆成人在线| 欧美系列精品| 国内精品久久久久影院薰衣草| 亚洲第一级黄色片| 亚洲色图在线视频| 久久国产日韩欧美| 欧美激情一区二区三区在线视频| 亚洲精选久久| 香蕉成人伊视频在线观看| 老鸭窝毛片一区二区三区| 国产精品xxxav免费视频| 精品9999| 亚洲天堂av高清| 久久一日本道色综合久久| 日韩西西人体444www| 久久福利精品| 欧美三级日韩三级国产三级| 国产亚洲精品自拍| 中文网丁香综合网| 老牛国产精品一区的观看方式| 亚洲精品乱码| 久久在线精品| 国产精品欧美一区二区三区奶水 | 久久久人成影片一区二区三区观看 | 免费国产一区二区| 国产精品综合色区在线观看| 亚洲国产一区二区精品专区| 亚洲一区综合| 欧美大片专区| 久久精品麻豆| 国产精品一二| 一区二区毛片| 男人的天堂亚洲| 欧美一区二区三区在| 欧美午夜不卡| 亚洲精品一区二区网址| 久久成人人人人精品欧| 亚洲精品一区在线观看| 久久久噜噜噜久久中文字幕色伊伊 | 老鸭窝亚洲一区二区三区|