• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0

            有四個(gè)剪枝:

            1、 已經(jīng)找到一個(gè)符合要求的解;

            2、 TIME至少要等于最短距離;

            3、 TIME至多等于走遍除H之外的其他地方;

            4、 這一個(gè)不是那么明顯,就是最短距離要和給定距離同奇偶。

            其中剪枝14尤為重要,23這兩個(gè)顯而易見的剪枝并沒有起到多大的效果。純搜索可以拿50分,234依然只可以拿50分,123可以拿60分,只要有了14就可以AC

            以下是我的代碼:

            #include<stdio.h>
            long n,m,time,h,dx,dy,dis,i,j,ans,used[55][55];
            char map[8][8];
            long xd[]={-1,0,1,0};
            long yd[]={0,-1,0,1};
            void dfs(long x,long y,long dep)
            {
                
            long i,t1,t2;
                
            if(dep>=time)
                
            {
                   
            if(map[x][y]=='D')
                     ans
            =1;
                   
            return;
                }

                
            for(i=0;i<4;i++)
                
            {
                   t1
            =x+xd[i];
                   t2
            =y+yd[i];
                  
            if(ans==0&&t1>=1&&t1<=n&&t2>=1&&t2<=m&&!used[t1][t2]&&(map[t1][t2]=='*'||map[t1][t2]=='D'))
                   
            {
                      used[t1][t2]
            =1;
                      dfs(t1,t2,dep
            +1);
                      used[t1][t2]
            =0;
                   }

                }

            }

            int main()
            {
                scanf(
            "%ld%ld%ld",&n,&m,&time);
               getchar();
                
            while(n!=0||m!=0||time!=0)
                
            {
                   
            for(i=0;i<=n+1;i++)
                     
            for(j=0;j<=m+1;j++)
                       map[i][j]
            ='#';
                   h
            =0;
                   
            for(i=1;i<=n;i++)
                   
            {
                      
            for(j=1;j<=m;j++)
                        scanf(
            "%c",&map[i][j]);
                      
            if(map[i][j]=='H')
                        h
            ++;
                      getchar();
                   }
            // Read
                   for(i=1;i<=n;i++)
                     
            for(j=1;j<=m;j++)
                       
            if(map[i][j]=='D')
                       
            {dx=i;dy=j;}
                   
            for(i=1;i<=n;i++)
                     
            for(j=1;j<=m;j++)
                       used[i][j]
            =0;
                   ans
            =0;
                   
            // Init
                   dis=dx+dy-2;
                   
            if(dis%2==time%2&&time>=dis&&time<=n*m-h)
                     dfs(
            1,1,0);
                   
            if(ans==1)
                     printf(
            "Yes\n");
                   
            else printf("No\n");
                   
            // Run
                   scanf("%ld%ld%ld",&n,&m,&time);
                   getchar();
                }

            return 0;
            }

            posted on 2010-01-06 19:55 lee1r 閱讀(158) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 題目分類:搜索
            久久婷婷国产剧情内射白浆| 国产精品欧美亚洲韩国日本久久| 嫩草影院久久99| 色综合久久久久综合体桃花网| 久久婷婷是五月综合色狠狠| 久久久精品久久久久特色影视| 国产国产成人久久精品| 久久91精品国产91久久户| 99久久99久久久精品齐齐| 国内精品久久久久影院优| 7777久久亚洲中文字幕| 99久久成人国产精品免费| 中文字幕一区二区三区久久网站 | 久久久人妻精品无码一区| 国内精品久久久久国产盗摄| 精品久久久久久无码人妻热| 久久久久久亚洲精品不卡| 久久午夜综合久久| 国产精品99久久久精品无码| 久久超乳爆乳中文字幕| 久久精品国产精品青草| 青春久久| 久久精品亚洲精品国产色婷| 日本一区精品久久久久影院| 日韩十八禁一区二区久久| 综合网日日天干夜夜久久| 国产欧美一区二区久久| 久久综合九色综合久99| 国内精品久久久久影院薰衣草 | 久久99精品久久久久久| 丁香久久婷婷国产午夜视频| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 97久久超碰国产精品旧版| 国产精品一区二区久久精品无码| 无码国内精品久久人妻麻豆按摩| 久久Av无码精品人妻系列| 久久99精品久久久久久不卡| 伊人久久大香线蕉亚洲五月天| 91秦先生久久久久久久| 午夜人妻久久久久久久久| 免费一级欧美大片久久网|