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

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年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導航

統計

公告

統計系統

留言簿(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久久中文| 欧美国产在线观看| 久久一区二区三区国产精品| 久久综合狠狠综合久久综青草| 老牛影视一区二区三区| 欧美成人综合一区| 亚洲国产欧美一区二区三区同亚洲 | 亚洲剧情一区二区| 亚洲精品日本| 亚洲欧美日韩高清| 久久久一区二区三区| 欧美成人免费在线视频| 欧美日本网站| 欧美在线观看视频一区二区三区| 亚洲伦理在线免费看| 国产精品白丝jk黑袜喷水| 国产精品一区二区在线观看不卡| 国产精品99久久久久久久久久久久| 免费不卡亚洲欧美| 欧美成人自拍| 一区二区三区产品免费精品久久75| 欧美一区二区免费| 欧美性大战xxxxx久久久| 久久综合狠狠| 亚洲精品三级| 国产一区二区三区高清| 亚洲欧美日韩国产中文 | 亚洲视频欧美视频| 国产亚洲一区在线| 亚洲免费福利视频| 在线一区观看| 亚洲黄网站黄| 亚洲影视九九影院在线观看| 欧美在线一级视频| 99精品久久| 国产一区二区电影在线观看| 在线中文字幕日韩| 免费人成网站在线观看欧美高清| 一区精品在线播放| 欧美日韩人人澡狠狠躁视频| 亚洲精品国产精品久久清纯直播| 在线亚洲欧美| 欧美日韩视频一区二区三区| 亚洲精品亚洲人成人网| 午夜精品久久久久久久久久久| 国产欧美日韩免费| 久久人人爽人人爽| 亚洲欧洲精品一区| 亚洲天堂av在线免费| 亚洲精品网站在线播放gif| 欧美在线综合| 亚洲日韩欧美视频一区| 欧美不卡一区| 久久久久久婷| 久久人人爽人人爽爽久久| 日韩一级大片| 亚洲无人区一区| av成人动漫| 亚洲视频免费| 亚洲性夜色噜噜噜7777| 一区二区三区四区精品| 久久久久欧美精品| 一区二区久久久久久| 久久精品一区二区三区四区| 久久嫩草精品久久久精品一| 亚洲在线免费| 日韩视频免费在线观看| 久久激情综合网| 欧美淫片网站| 久久精品国产2020观看福利| 激情欧美一区| 免费久久99精品国产自| 亚洲成人自拍视频| 亚洲国产人成综合网站| 99re热这里只有精品免费视频| 亚洲精品国产拍免费91在线| 一本一本久久a久久精品综合麻豆| 亚洲一区二区网站| 亚洲欧美在线看| 久久亚洲精品网站| 暖暖成人免费视频| 久久精品国产亚洲aⅴ| 亚洲精品美女在线观看| 亚洲激情网站免费观看| 亚洲欧美日产图| 理论片一区二区在线| 欧美一区二区私人影院日本| 久久综合伊人77777蜜臀| 欧美视频在线免费看| 亚洲国产成人在线视频| 91久久综合亚洲鲁鲁五月天| 久久精品国产第一区二区三区最新章节| 久久青草福利网站| 欧美a级一区| 欧美专区在线观看一区| 国产精品久久网| 亚洲韩日在线| 亚洲欧美高清| 亚洲国产精品久久久久| 老色鬼久久亚洲一区二区| 久久激情五月激情| 日韩视频一区二区| 亚洲嫩草精品久久| 欧美大片在线看| 国内精品久久久久久久果冻传媒| 美女久久网站| 蜜臀久久99精品久久久画质超高清| 亚洲性视频网址| 一区福利视频| 欧美诱惑福利视频| 久久精品国产亚洲精品| 欧美日韩一区二区在线| 一区二区三区欧美| 欧美日韩日本国产亚洲在线| 在线综合亚洲欧美在线视频| 久久综合中文字幕| 欧美精品成人91久久久久久久| 久久高清福利视频| 午夜精品久久久久久久99热浪潮| 国产精品日韩欧美一区二区三区 | 欧美一区二区三区婷婷月色 | 中文亚洲免费| 国产精品一区久久| 亚洲国产婷婷香蕉久久久久久| 欧美区一区二区三区| 欧美一级大片在线观看| 久久免费视频网站| 久久九九免费| 国产精品三区www17con| 亚洲人精品午夜| 亚洲麻豆av| 久久久亚洲国产美女国产盗摄| 欧美综合国产精品久久丁香| 欧美日韩福利| 日韩午夜激情电影| 欧美在线高清| 久久精品一区四区| 亚洲大黄网站| 在线欧美三区| 麻豆免费精品视频| 欧美中文字幕在线| 韩国成人精品a∨在线观看| 亚洲欧美久久久| 亚洲第一视频网站| 日韩视频在线一区二区三区| 欧美性感一类影片在线播放| 欧美成人dvd在线视频| 亚洲一区欧美一区| 亚洲人体影院| 欧美在线视频一区二区三区| 亚洲精品久久在线| 国内精品久久久久久| 欧美日韩国产麻豆| 一区二区三区四区五区精品视频| 亚洲图片欧洲图片av| 欧美日韩久久不卡| 理论片一区二区在线| 亚洲人午夜精品免费| 亚洲特色特黄| 亚洲免费成人| 亚洲一区二区三区高清不卡| 狠狠色噜噜狠狠狠狠色吗综合| 怡红院精品视频在线观看极品| 国产精品免费一区豆花| 久久久成人精品| 久久久久久一区二区三区| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲欧美中文日韩在线| 黄色一区二区三区| 欧美视频在线观看一区| 免费在线一区二区| 欧美激情欧美狂野欧美精品| 老牛国产精品一区的观看方式| 亚洲国产成人在线播放| 欧美成人性网| 欧美sm极限捆绑bd| 韩国三级电影一区二区| 欧美日韩中文在线| 欧美日韩免费一区二区三区| 欧美影院视频| 久久久国产一区二区| 欧美日韩免费一区| 国产精品欧美精品| 亚洲第一精品福利| 国产综合精品| 亚洲欧美文学| 久久久久久**毛片大全| 久久久久国产一区二区三区| 亚洲电影免费观看高清| 久久成人免费视频| 国产亚洲精品激情久久| 亚洲第一在线综合网站| 免费成人黄色| 欧美另类一区二区三区| 亚洲国产精彩中文乱码av在线播放| 久久久久网址| 久久疯狂做爰流白浆xx|