• <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>

            pku2384 Harder Sokoban Problem 推箱子游戲,DP

            題目不用解釋了,給出箱子的箱子的終點,求箱子的起點以及人的起點,使得人把箱子推到終點需要的最長步數。
            我是從終點向起點DP的,就要考慮一種特殊情況:箱子開始就只能在終點,不可能在其他任何位置。
            狀態轉移比較麻煩,分為8種情況,詳情看代碼吧

              1# include <iostream>
              2# include <cstring>
              3# include <queue>
              4using namespace std;
              5# define encode(r1,c1,r2,c2) (((((((r1)<<5)|(c1))<<5)|(r2))<<5)|(c2))
              6# define getr1(pos) ((pos)>>15)
              7# define getc1(pos) (((pos)>>10)&31)
              8# define getr2(pos) (((pos)>>5)&31)
              9# define getc2(pos) ((pos)&31)
             10# define legal(r,c) (map[r][c]!='#')
             11# define equal(r1,c1,r2,c2) ((r1)==(r2)&&(c1)==(c2))
             12# define max(a,b) ((a)>(b)?(a):(b))
             13int dp[2000000],n;
             14char map[30][30];
             15queue<int> q;
             16int solve(int r,int c)
             17{
             18    int res=0;
             19    if(r!=n-1&&map[r+1][c]!='#')
             20    {
             21       dp[encode(r,c,r+1,c)]=0;
             22       q.push(encode(r,c,r+1,c));
             23    }

             24    if(r!=0&&map[r-1][c]!='#')
             25    {
             26       dp[encode(r,c,r-1,c)]=0;
             27       q.push(encode(r,c,r-1,c));
             28    }

             29    if(c!=0&&map[r][c-1]!='#')
             30    {
             31       dp[encode(r,c,r,c-1)]=0;
             32       q.push(encode(r,c,r,c-1));
             33    }

             34    if(c!=n-1&&map[r][c+1]!='#')
             35    {
             36       dp[encode(r,c,r,c+1)]=0;
             37       q.push(encode(r,c,r,c+1));
             38    }

             39    while(!q.empty())
             40    {
             41       int boxr=getr1(q.front()),boxc=getc1(q.front()),perr=getr2(q.front()),perc=getc2(q.front());
             42       if(!equal(r,c,boxr,boxc))res=max(res,dp[q.front()]);
             43       q.pop();
             44       if(perr!=n-1&&map[perr+1][perc]!='#'&&!equal(boxr,boxc,perr+1,perc)&&dp[encode(boxr,boxc,perr+1,perc)]==-1)
             45       {
             46          dp[encode(boxr,boxc,perr+1,perc)]=dp[encode(boxr,boxc,perr,perc)]+1;
             47          q.push(encode(boxr,boxc,perr+1,perc));
             48       }

             49       if(perr!=0&&map[perr-1][perc]!='#'&&!equal(boxr,boxc,perr-1,perc)&&dp[encode(boxr,boxc,perr-1,perc)]==-1)
             50       {
             51          dp[encode(boxr,boxc,perr-1,perc)]=dp[encode(boxr,boxc,perr,perc)]+1;
             52          q.push(encode(boxr,boxc,perr-1,perc));
             53       }

             54       if(perc!=0&&map[perr][perc-1]!='#'&&!equal(boxr,boxc,perr,perc-1)&&dp[encode(boxr,boxc,perr,perc-1)]==-1)
             55       {
             56          dp[encode(boxr,boxc,perr,perc-1)]=dp[encode(boxr,boxc,perr,perc)]+1;
             57          q.push(encode(boxr,boxc,perr,perc-1));
             58       }

             59       if(perc!=n-1&&map[perr][perc+1]!='#'&&!equal(boxr,boxc,perr,perc+1)&&dp[encode(boxr,boxc,perr,perc+1)]==-1)
             60       {
             61          dp[encode(boxr,boxc,perr,perc+1)]=dp[encode(boxr,boxc,perr,perc)]+1;
             62          q.push(encode(boxr,boxc,perr,perc+1));
             63       }

             64       if(equal(boxr,boxc,perr+1,perc)&&perr!=0&&map[perr-1][perc]!='#'&&dp[encode(boxr-1,boxc,perr-1,perc)]==-1)
             65       {
             66          dp[encode(boxr-1,boxc,perr-1,perc)]=dp[encode(boxr,boxc,perr,perc)]+1;
             67          q.push(encode(boxr-1,boxc,perr-1,perc));
             68       }

             69       if(equal(boxr,boxc,perr-1,perc)&&perr!=n-1&&map[perr+1][perc]!='#'&&dp[encode(boxr+1,boxc,perr+1,perc)]==-1)
             70       {
             71          dp[encode(boxr+1,boxc,perr+1,perc)]=dp[encode(boxr,boxc,perr,perc)]+1;
             72          q.push(encode(boxr+1,boxc,perr+1,perc));
             73       }

             74       if(equal(boxr,boxc,perr,perc+1)&&perc!=0&&map[perr][perc-1]!='#'&&dp[encode(boxr,boxc-1,perr,perc-1)]==-1)
             75       {
             76         dp[encode(boxr,boxc-1,perr,perc-1)]=dp[encode(boxr,boxc,perr,perc)]+1;
             77         q.push(encode(boxr,boxc-1,perr,perc-1));
             78       }

             79       if(equal(boxr,boxc,perr,perc-1)&&perc!=n-1&&map[perr][perc+1]!='#'&&dp[encode(boxr,boxc+1,perr,perc+1)]==-1)
             80       {
             81         dp[encode(boxr,boxc+1,perr,perc+1)]=dp[encode(boxr,boxc,perr,perc)]+1;
             82         q.push(encode(boxr,boxc+1,perr,perc+1));
             83       }
             
             84    }

             85    return res;
             86}

             87int main()
             88{
             89    memset(dp,-1,sizeof(dp));
             90    cin>>n;
             91    for(int i=0;i<n;i++)
             92       cin>>map[i];
             93     int tr,tc;
             94     for(int i=0;i<n;i++)
             95       for(int j=0;j<n;j++)
             96         if(map[i][j]=='*')
             97          {
             98             tr=i;
             99             tc=j;
            100             goto endloop;
            101          }

            102endloop:;
            103    // if(n==2)
            104        //   cout<<0<<endl;
            105    // else
            106          cout<<solve(tr,tc)<<endl;         
            107     return 0;   
            108}

            109
            110

            posted on 2010-10-30 23:34 yzhw 閱讀(231) 評論(0)  編輯 收藏 引用 所屬分類: DPgraph

            <2011年1月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            伊人久久大香线蕉av不卡| 久久精品国产精品亜洲毛片| 久久久久无码中| 亚洲精品99久久久久中文字幕| 久久99精品久久久大学生| 狠狠色丁香婷综合久久| 国产精品成人99久久久久| 波多野结衣久久一区二区 | 香蕉久久夜色精品国产小说| 伊人久久大香线蕉综合5g| 久久av无码专区亚洲av桃花岛| 欧美午夜精品久久久久久浪潮| 久久成人国产精品| 色综合合久久天天综合绕视看 | 国产ww久久久久久久久久| 欧美精品九九99久久在观看| 色综合色天天久久婷婷基地 | 久久精品无码专区免费东京热| 国产免费久久精品丫丫| 久久Av无码精品人妻系列 | 四虎影视久久久免费| 久久精品国产亚洲精品2020| 一级做a爰片久久毛片免费陪| 国产成人精品久久综合| 人妻丰满AV无码久久不卡| 无码任你躁久久久久久老妇App| 秋霞久久国产精品电影院| 日韩人妻无码精品久久久不卡 | 国产精品久久久久aaaa| 久久亚洲欧美国产精品| 亚洲色欲久久久久综合网| 九九久久精品国产| 中文成人久久久久影院免费观看| 91精品婷婷国产综合久久| 香蕉久久夜色精品国产小说| 久久亚洲国产中v天仙www | 久久精品水蜜桃av综合天堂| 精品国产青草久久久久福利| 久久国产色av免费看| 日产精品久久久久久久| 99久久这里只有精品|