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

            pku 3009

            2009年8月10日

            題目鏈接:PKU 3009 Curling 2.0

            分類:一道經(jīng)典DFS

            題目分析與算法原型
                     沒什么特別講的,直接dfs,沒加什么減枝的情況下,跑了250ms左右(暫時(shí)沒想到好的剪枝策略).........看到這題之后思路比較清晰,對于每個(gè)位置,枚舉上,下,左,右四個(gè)方向,對于每個(gè)方向若沒有相鄰的障礙物則表示可以從這個(gè)方向丟,那么一直從這個(gè)方向找,一直到遇到障礙,則從這個(gè)障礙的位置繼續(xù)dfs,若出了板子,表示該方向不可丟,繼續(xù)下個(gè)方向的判斷,若當(dāng)前次數(shù)大于10次則返回,若在10之內(nèi)到達(dá)了終點(diǎn)并且所有次數(shù)比當(dāng)前最小的次數(shù)還小,則更新最小次數(shù)...........


            Code:

             1
            #include<stdio.h>
             2#include<string.h>
             3#define len 25
             4#define max 0x7fffffff                //0上,1下,2左,3右                                             
             5int w,h,map[len][len],beg[2],min,step[4][2]={{-1,0},{1,0},{0,-1},{0,1}};
             6bool flag[len][len];
             7bool check(int x,int y)
             8{
             9    if(x>=0&&x<=h-1&&y>=0&&y<=w-1)return true;
            10    else return false;
            11}

            12void dfs(int count,int x,int y)
            13{
            14    int i,px,py;
            15    if(count>10)return;
            16    for(i=0;i<4;i++)
            17    {
            18        px=x+step[i][0];
            19        py=y+step[i][1];
            20        
            21        if(!flag[px][py]&&check(px,py))
            22        {    
            23            while(map[px][py]!=3&&!flag[px][py]&&check(px,py))
            24            {
            25                px+=step[i][0];
            26                py+=step[i][1];
            27            }

            28            if(check(px,py))
            29            {
            30                if(flag[px][py])
            31                {
            32                    flag[px][py]=false;
            33                    dfs(count+1,px-step[i][0],py-step[i][1]);
            34                    flag[px][py]=true;
            35                }

            36                else
            37                {
            38                    if(count+1<=10&&count<min)min=count+1;
            39                    return ;
            40                }

            41            }

            42        }

            43    }

            44    return ;
            45}

            46int main()
            47{
            48    int i,j;
            49    while(scanf("%d%d",&w,&h)!=EOF)
            50    {
            51        if(!w&&!h)break;
            52        memset(flag,false,sizeof(flag));
            53        for(i=0;i<h;i++)
            54            for(j=0;j<w;j++)
            55            {
            56                scanf("%d",&map[i][j]);
            57                if(map[i][j]==2)
            58                {
            59                    beg[0]=i;
            60                    beg[1]=j;
            61                }

            62                else if(map[i][j]==1)flag[i][j]=true;
            63            }

            64            min=max;
            65            dfs(0,beg[0],beg[1]);
            66            if(min<max)printf("%d\n",min);
            67            else printf("-1\n");
            68    }

            69    return 1;
            70}

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


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


            <2009年6月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(8)

            隨筆檔案(78)

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            評論排行榜

            国产亚洲精久久久久久无码| 久久精品一区二区三区不卡| 精品久久久久一区二区三区| 久久精品成人| 久久婷婷五月综合国产尤物app| 国产成年无码久久久久毛片| 亚洲国产成人久久综合一区77| 久久精品国产亚洲AV香蕉| 久久精品www| 久久人人添人人爽添人人片牛牛| 久久人人爽人人爽人人片AV不 | 亚洲午夜无码久久久久小说| 成人妇女免费播放久久久| 四虎国产精品成人免费久久| 综合久久给合久久狠狠狠97色| 国内精品人妻无码久久久影院导航| 久久精品国产欧美日韩| 91亚洲国产成人久久精品网址 | 久久一区二区三区99| 免费国产99久久久香蕉| 99精品伊人久久久大香线蕉| 看全色黄大色大片免费久久久 | 国産精品久久久久久久| 国产精品午夜久久| 亚洲欧美成人久久综合中文网 | 奇米综合四色77777久久| 99精品国产在热久久无毒不卡 | 亚洲国产精品无码久久一区二区 | 久久久久久伊人高潮影院| 久久天天躁狠狠躁夜夜avapp| 2022年国产精品久久久久| 日批日出水久久亚洲精品tv| 2021少妇久久久久久久久久| 久久婷婷色综合一区二区| 99久久国产免费福利| 久久精品毛片免费观看| 伊人久久大香线蕉无码麻豆| 人妻精品久久久久中文字幕| 亚洲午夜福利精品久久| 欧美激情精品久久久久| 久久这里只精品国产99热|