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

            <2010年10月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            精品国产婷婷久久久| 无码8090精品久久一区| 久久无码人妻一区二区三区午夜| 国产精品久久久久国产A级| 色噜噜狠狠先锋影音久久| 成人综合久久精品色婷婷| 久久国产精品久久久| 久久受www免费人成_看片中文| 99re这里只有精品热久久| 欧美伊人久久大香线蕉综合| 中文字幕久久欲求不满| 久久亚洲日韩看片无码| 国产L精品国产亚洲区久久| 久久国产欧美日韩精品| 免费一级欧美大片久久网| 精品国产一区二区三区久久久狼| 人妻无码久久精品| 国产成人精品久久综合| 精品久久久久久国产潘金莲| 成人综合久久精品色婷婷| 免费一级做a爰片久久毛片潮| 国产精品99精品久久免费| 色综合久久久久无码专区| 香蕉99久久国产综合精品宅男自 | 亚洲国产成人久久笫一页| 精品国际久久久久999波多野| 亚洲色欲久久久综合网东京热| 亚洲人成网站999久久久综合| 精品综合久久久久久88小说| 欧美激情精品久久久久| 精品久久久久久国产潘金莲| 人妻精品久久无码专区精东影业 | 一本一本久久a久久综合精品蜜桃| 精品无码人妻久久久久久| 国产亚洲精午夜久久久久久 | 九九99精品久久久久久| 久久99国产精品久久久| 久久久久综合网久久| 国内精品伊人久久久久网站| 国产精自产拍久久久久久蜜| 久久精品无码免费不卡|