青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

pku 1198 Solitaire 搜索+剪枝

題意:
      應該是跳棋游戲(我奶奶經常在家玩。。),一個8*8棋盤,棋子可以在棋盤上前后左右挪一格或者跳一格(如果相鄰格子有棋子的話),問初始狀態在8步內能否達到給定的終止狀態。
下限函數仍然選擇不在位置上的棋子個數,然后減枝即可。。
話說POJ卡常數,覺得復雜度應該可以了,就是TLE,然后到TOJ上嘗試提交了下,1A,然后只好回來優化常數,把判重換成數組判重,以6S的時間過了。。哎,JAVA就是可憐啊。。
  1 import java.util.*;
  2 import java.io.*;
  3 public class Main {
  4 
  5     /**
  6      * @param args
  7      */
  8     static point p1[]=new point[4],p2[]=new point[4];
  9     static boolean map[][]=new boolean[10][10];
 10     static boolean map1[][]=new boolean[10][10];
 11     static class point
 12     {
 13         int r,c;
 14         public point(int rr,int cc)
 15         {
 16             r=rr;
 17             c=cc;
 18         }
 19         public boolean equals(point pos)
 20         {
 21             return r==pos.r&&c==pos.c;
 22         }
 23     }
 24     static final boolean isnotin(int r,int c,point p[])
 25     {
 26         for(int i=0;i<4;i++)
 27             if(p[i].r==r&&p[i].c==c)
 28                 return false;
 29         return true;
 30     }
 31     static boolean dfs(point p[],int diff,int layer)
 32     {
 33         if(layer+diff>8return false;
 34         else if(diff==0
 35         {
 36             return true;
 37         
 38         }
 39         else
 40         {
 41             for(int i=0;i<4;i++)
 42             {
 43                 if(p[i].r+1<8&&isnotin(p[i].r+1,p[i].c,p))
 44                 {
 45                     p[i].r++;
 46                     if(dfs(p,diff+(isnotin(p[i].r-1,p[i].c,p2)?0:1)-(map[p[i].r][p[i].c]?1:0),layer+1)) 
 47                         {
 48                     
 49                             return true;
 50                         }
 51                     p[i].r--;
 52                 }
 53                 if(p[i].c+1<8&&isnotin(p[i].r,p[i].c+1,p))
 54                 {
 55                     p[i].c++;
 56                     if(dfs(p,diff+(isnotin(p[i].r,p[i].c-1,p2)?0:1)-(map[p[i].r][p[i].c]?1:0),layer+1)) 
 57                     {
 58                     
 59                         return true;
 60                     }
 61                     p[i].c--;
 62                 }
 63                 if(p[i].c-1>=0&&isnotin(p[i].r,p[i].c-1,p))
 64                 {
 65                     p[i].c--;
 66                     if(dfs(p,diff+(isnotin(p[i].r,p[i].c+1,p2)?0:1)-(map[p[i].r][p[i].c]?1:0),layer+1)) 
 67                     {
 68                         
 69                         return true;
 70                     }
 71                     p[i].c++;
 72                 }
 73                 if(p[i].r-1>=0&&isnotin(p[i].r-1,p[i].c,p))
 74                 {
 75                     p[i].r--;
 76                     if(dfs(p,diff+(isnotin(p[i].r+1,p[i].c,p2)?0:1)-(map[p[i].r][p[i].c]?1:0),layer+1)) 
 77                     {
 78                         
 79                         return true;
 80                     }
 81                     p[i].r++;
 82                 }
 83                 
 84                 if(p[i].r+2<8&&isnotin(p[i].r+2,p[i].c,p)&&!isnotin(p[i].r+1,p[i].c,p))
 85                 {
 86                     p[i].r+=2;
 87                     if(dfs(p,diff+(isnotin(p[i].r-2,p[i].c,p2)?0:1)-(map[p[i].r][p[i].c]?1:0),layer+1))
 88                     {
 89                         
 90                         return true;
 91                     }
 92                     p[i].r-=2;
 93                     
 94                 }
 95                 if(p[i].c+2<8&&isnotin(p[i].r,p[i].c+2,p)&&!isnotin(p[i].r,p[i].c+1,p))
 96                 {
 97                     p[i].c+=2;
 98                     if(dfs(p,diff+(isnotin(p[i].r,p[i].c-2,p2)?0:1)-(map[p[i].r][p[i].c]?1:0),layer+1)) 
 99                     {
100                         
101                         return true;
102                     }
103                     p[i].c-=2;
104                 }
105                 if(p[i].c-2>=0&&isnotin(p[i].r,p[i].c-2,p)&&!isnotin(p[i].r,p[i].c-1,p))
106                 {
107                     p[i].c-=2;
108                     if(dfs(p,diff+(isnotin(p[i].r,p[i].c+2,p2)?0:1)-(map[p[i].r][p[i].c]?1:0),layer+1)) 
109                     {
110                         
111                         return true;
112                     }
113                     p[i].c+=2;
114                 }
115                 if(p[i].r-2>=0&&isnotin(p[i].r-2,p[i].c,p)&&!isnotin(p[i].r-1,p[i].c,p))
116                 {
117                     p[i].r-=2;
118                     if(dfs(p,diff+(isnotin(p[i].r+2,p[i].c,p2)?0:1)-(map[p[i].r][p[i].c]?1:0),layer+1)) 
119                     {
120                         
121                         return true;
122                     }
123                     p[i].r+=2;
124                 }
125                 
126                 
127             }
128             return false;
129         }
130     }
131     public static void main(String[] args) throws IOException{
132         Scanner in=new Scanner(new BufferedReader(new InputStreamReader(System.in)));
133         for(int i=0;i<4;i++)
134            p1[i]=new point(in.nextInt()-1,in.nextInt()-1);
135         for(int i=0;i<4;i++)
136            p2[i]=new point(in.nextInt()-1,in.nextInt()-1);
137         for(int i=0;i<8;i++)
138         {
139             Arrays.fill(map[i], false);
140             Arrays.fill(map1[i],false);
141         }
142         for(int i=0;i<4;i++)
143         {
144             map[p2[i].r][p2[i].c]=true;
145             map1[p1[i].r][p1[i].c]=true;
146         }
147         int diff=0;
148         for(int i=0;i<4;i++)
149         {
150             boolean flag=false;
151             for(int j=0;j<4&&!flag;j++)
152                 if(p1[i].equals(p2[j]))
153                     flag=true;
154             if(!flag) diff++;
155         }
156         if(dfs(p1,diff,0)) System.out.println("YES");
157         else System.out.println("NO");
158 
159     }
160 
161 }
162 


posted on 2010-10-16 01:50 yzhw 閱讀(218) 評論(0)  編輯 收藏 引用 所屬分類: search

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

導航

統計

公告

統計系統

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            一区二区三区四区国产| 日韩视频中文字幕| 麻豆精品91| 欧美波霸影院| 欧美日韩你懂的| 亚洲一区日韩在线| 亚洲午夜精品17c| 亚洲影院一区| 久久精选视频| 欧美电影在线观看完整版| 欧美91大片| 亚洲黄色视屏| 日韩午夜中文字幕| 午夜精品视频在线观看| 久久久精品国产免费观看同学| 久久一本综合频道| 欧美日韩一区二| 国产亚洲在线| 一本色道精品久久一区二区三区| 亚洲视频国产视频| 久久精品夜色噜噜亚洲a∨| 欧美不卡视频一区发布| 99精品国产在热久久婷婷| 欧美一区二区免费视频| 欧美成人激情在线| 国产精品视频成人| 亚洲国产精品成人va在线观看| 一区二区三区高清在线| 久久久久久精| 日韩视频第一页| 久久久亚洲一区| 国产精品高潮视频| 亚洲国产日韩精品| 久久成人一区| 亚洲免费大片| 欧美成人四级电影| 国内精品久久久久久久97牛牛| 中文一区字幕| 欧美国产视频日韩| 欧美一区亚洲| 国产精品美女999| 亚洲美女毛片| 老鸭窝91久久精品色噜噜导演| 一区二区免费在线播放| 欧美激情第二页| 亚洲第一成人在线| 久久激情五月丁香伊人| 亚洲视频精品在线| 欧美日韩国产a| 亚洲精品一区二区三区婷婷月| 久久久www| 翔田千里一区二区| 国产精品久久久久久久久果冻传媒| 亚洲人成网站色ww在线| 免费日韩一区二区| 欧美伊久线香蕉线新在线| 国产美女精品| 欧美在线看片| 久久成人av少妇免费| 国产美女精品| 久久精品中文字幕一区二区三区 | 欧美成人精品影院| 欧美mv日韩mv国产网站| 黄色成人av在线| 久久免费视频在线| 欧美在线高清| 精品91视频| 欧美国产高清| 欧美精品在线网站| 亚洲婷婷在线| 亚洲一区久久久| 国产精品一区二区在线观看不卡 | 日韩亚洲视频| 国产精品国产三级国产aⅴ浪潮| 中文一区二区| 午夜精品久久一牛影视| 国产综合精品| 欧美刺激午夜性久久久久久久| 另类激情亚洲| 亚洲天堂久久| 欧美在线视频二区| 亚洲人成免费| 亚洲午夜免费视频| 国产一区二区无遮挡| 免费欧美网站| 欧美性色综合| 麻豆国产精品一区二区三区| 欧美成人精品在线播放| 亚洲综合大片69999| 久久激情视频久久| 99爱精品视频| 欧美一区二区高清在线观看| 亚洲精品一级| 欧美一区二区三区免费观看视频| 亚洲高清视频在线观看| 一区二区三区精品国产| 狠狠色狠狠色综合系列| 9l视频自拍蝌蚪9l视频成人| 国色天香一区二区| 日韩亚洲精品电影| 极品尤物一区二区三区| 99riav1国产精品视频| 国外成人在线| 亚洲淫性视频| 一区二区三区日韩| 久久国产婷婷国产香蕉| 一区二区三区 在线观看视| 久久激情五月激情| 亚洲一区二区精品视频| 免费成人av在线| 久久福利电影| 欧美视频专区一二在线观看| 欧美成人一区二区在线| 国产欧美欧美| 亚洲精品欧美激情| 亚洲第一黄色| 久久精品二区三区| 欧美一进一出视频| 欧美日韩亚洲综合一区| 亚洲国产精品va在线看黑人动漫 | 亚洲精品一级| 久久国产精品久久w女人spa| 性8sex亚洲区入口| 欧美午夜精品久久久久久孕妇| 欧美激情日韩| 伊伊综合在线| 欧美专区亚洲专区| 久久久亚洲高清| 国产日韩欧美综合一区| 中文在线资源观看视频网站免费不卡| 亚洲国产欧美一区二区三区丁香婷| 欧美专区日韩专区| 久久久国产亚洲精品| 国产精品视频免费在线观看| 一区二区三区偷拍| 亚洲综合色丁香婷婷六月图片| 欧美日韩精品免费在线观看视频| 91久久夜色精品国产网站| 亚洲日韩欧美视频一区| 欧美a级大片| 亚洲黄一区二区| 一本一道久久综合狠狠老精东影业| 牛牛国产精品| 亚洲人成网站精品片在线观看| 99国产精品久久久久久久久久| 欧美a级一区二区| 亚洲精品国精品久久99热一| 一区二区三区 在线观看视| 欧美三级视频| 亚洲欧美日韩人成在线播放| 欧美在线免费观看| 亚洲成人在线| 欧美激情视频网站| 9色精品在线| 久久黄色级2电影| 亚洲黄色一区| 国产精品久久久久久久久久妞妞| 亚洲综合色在线| 麻豆国产精品一区二区三区| 亚洲看片网站| 国产精品欧美久久久久无广告| 午夜视频在线观看一区二区三区| 久久久久这里只有精品| 亚洲欧洲午夜| 国产精品男人爽免费视频1| 久久久精品999| 日韩视频一区二区三区| 久久久不卡网国产精品一区| 亚洲欧洲日产国产网站| 国产精品亚洲激情| 蜜桃av一区二区| 亚洲一区二区三区影院| 蜜桃av噜噜一区| 亚洲欧美成aⅴ人在线观看| 极品日韩久久| 国产精品色午夜在线观看| 老色鬼精品视频在线观看播放| 99国内精品| 欧美二区在线观看| 欧美一级精品大片| 亚洲美女诱惑| 激情综合色综合久久| 国产精品久久夜| 欧美岛国激情| 久久国产精品99久久久久久老狼| 亚洲精品日本| 你懂的亚洲视频| 久久超碰97人人做人人爱| 亚洲精品乱码久久久久久久久| 国产一区二区三区视频在线观看| 91久久精品一区| 韩国一区二区三区美女美女秀| 欧美成人激情视频| 欧美一区二区私人影院日本| 亚洲美女视频| 欧美激情久久久| 欧美大色视频| 免费高清在线一区| 久久精品人人爽| 午夜欧美大片免费观看|