• <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 閱讀(221) 評論(0)  編輯 收藏 引用 所屬分類: DPgraph

            <2010年11月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            亚洲国产成人精品女人久久久| 成人亚洲欧美久久久久| 久久精品国产久精国产| 囯产极品美女高潮无套久久久| 久久99精品久久久久久齐齐| 婷婷综合久久中文字幕| 久久99热精品| 久久r热这里有精品视频| 97热久久免费频精品99| 久久国产欧美日韩精品| 亚洲精品乱码久久久久66| 精品久久久无码21p发布| 欧美亚洲国产精品久久高清 | 国内精品综合久久久40p| 欧美日韩精品久久免费| 久久久久久国产精品美女| 久久久久久久久久久久久久 | 97精品伊人久久久大香线蕉| 亚洲精品国产第一综合99久久 | 亚洲国产精品无码久久久蜜芽| 久久精品一本到99热免费| AV无码久久久久不卡蜜桃| 青青草原精品99久久精品66| 久久国产精品无码HDAV| 久久青草国产手机看片福利盒子| 亚洲精品高清久久| 亚洲人AV永久一区二区三区久久 | 久久夜色精品国产噜噜亚洲AV| 久久99精品久久久久婷婷| 久久亚洲国产精品一区二区| 国内精品久久久久影院网站| 久久亚洲AV成人无码软件| 色综合久久无码五十路人妻| 亚洲一区中文字幕久久| 久久伊人五月天论坛| 久久99热这里只有精品国产| 国产亚洲婷婷香蕉久久精品| 国产精品午夜久久| 伊人久久大香线蕉综合影院首页 | 久久频这里精品99香蕉久| 亚洲人成精品久久久久|