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

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>
            亚洲国产人成综合网站| 男男成人高潮片免费网站| 亚洲高清视频的网址| 亚洲欧美日韩视频二区| 亚洲国产精品专区久久| 99re66热这里只有精品3直播 | 午夜精品久久久久久99热| 欧美色欧美亚洲高清在线视频| 亚洲字幕在线观看| 亚洲一级黄色av| 欧美日韩视频在线一区二区观看视频| 亚洲欧美日韩精品久久亚洲区 | 亚洲丶国产丶欧美一区二区三区| 久久久999精品免费| 一本色道久久综合亚洲91| 亚洲激情校园春色| 久久久久欧美精品| 国产综合视频| 久久久国产91| 亚洲影院一区| 欧美性一区二区| 亚欧成人在线| 中文久久乱码一区二区| 亚洲私人影院| 国产嫩草影院久久久久| 亚洲综合二区| 亚洲国产第一页| 欧美 日韩 国产 一区| 韩国在线一区| av成人老司机| 亚洲图片你懂的| 国产精品久久久久久久第一福利| 蜜桃视频一区| 宅男精品导航| 亚洲视频视频在线| 欧美经典一区二区三区| 99综合在线| 99视频一区| 国产午夜亚洲精品羞羞网站| 久久精品最新地址| 午夜精品久久久久99热蜜桃导演| 国产三区精品| 国产一区导航| 性欧美xxxx大乳国产app| 久久国产精品免费一区| 亚洲国产精品久久人人爱蜜臀| 亚洲欧美欧美一区二区三区| 欧美伊人精品成人久久综合97| 玖玖综合伊人| 亚洲电影自拍| 性欧美激情精品| 亚洲欧美高清| 亚洲一级电影| 亚洲国语精品自产拍在线观看| 激情偷拍久久| 免费看的黄色欧美网站| 欧美成人在线免费视频| 欧美与黑人午夜性猛交久久久| 欧美一区午夜精品| 亚洲黄色成人久久久| 亚洲一区日韩| 亚洲缚视频在线观看| 亚洲精品免费看| 狠狠干狠狠久久| 亚洲美女淫视频| 欧美日本在线看| 美乳少妇欧美精品| 欧美精品在线视频| 欧美日本中文| 1024成人| 美日韩在线观看| 国产精品日韩欧美大师| 久久久久久久久岛国免费| 欧美激情一区在线| 妖精成人www高清在线观看| 久久精品国产精品| 亚洲视频一二区| 中文日韩在线视频| 91久久国产综合久久| 亚洲一区影院| 亚洲免费影视第一页| 欧美电影资源| 亚洲一区二区三区精品动漫| 欧美国产日产韩国视频| 久久久久青草大香线综合精品| 国产精品日韩欧美一区二区三区 | 99精品免费| 国产精品日韩欧美一区| 一区二区三区久久久| 在线播放日韩| 久久久www成人免费无遮挡大片 | 性做久久久久久久免费看| 久久婷婷国产综合尤物精品| 亚洲永久在线| 欧美午夜电影在线观看| 亚洲欧美国产77777| 99视频在线观看一区三区| 欧美日韩中文在线观看| 亚洲国产黄色| 欧美成人xxx| 另类专区欧美制服同性| 国产欧亚日韩视频| 久久福利视频导航| 午夜激情亚洲| 欧美777四色影视在线| 欧美成人精品福利| 激情五月婷婷综合| 久久一本综合频道| 老牛国产精品一区的观看方式| 国产麻豆91精品| 亚洲视频碰碰| 亚洲欧美日韩精品在线| 久久亚洲国产成人| 久久久精品欧美丰满| 国产美女一区二区| 久久一二三国产| 亚洲第一区在线| 久久av老司机精品网站导航| 玖玖综合伊人| 国产专区综合网| 欧美高清在线播放| 亚洲精选在线| 国产综合自拍| 欧美人与禽猛交乱配| 亚洲人成网站色ww在线| 午夜精品久久久久久久99热浪潮 | 欧美激情中文不卡| 一区二区三区欧美亚洲| 欧美天堂在线观看| 亚洲网站在线看| 玖玖视频精品| 亚洲精品九九| 欧美日韩成人在线| 欧美一区日韩一区| 男同欧美伦乱| 亚洲综合丁香| 一区二区在线看| 欧美精品免费看| 欧美在线网址| 亚洲精品美女在线观看播放| 99re6这里只有精品| 国产热re99久久6国产精品| 久久久国产午夜精品| 一区二区成人精品| 久久久免费精品视频| 亚洲另类黄色| 国产一区二区三区最好精华液| 久久综合中文| 欧美一级一区| 亚洲日本视频| 国产欧美一区二区白浆黑人| 欧美日韩国产影院| 欧美永久精品| 亚洲一区二区免费| 亚洲大片在线| 欧美专区在线| 国产三级精品在线不卡| 国产精品社区| 蜜桃久久av一区| 亚洲欧美韩国| 亚洲一区二区三区午夜| 欧美 日韩 国产在线| 午夜在线播放视频欧美| 欧美18av| 国产精品亚洲美女av网站| 欧美韩日视频| 久久成人免费日本黄色| 老妇喷水一区二区三区| 久久久久久久久久看片| 欧美日韩123| 欧美专区在线| 欧美大片在线观看一区二区| 亚洲一二三区视频在线观看| 亚洲大片一区二区三区| 欧美777四色影视在线| 亚洲深夜激情| 欧美电影免费观看网站| 欧美一区二区三区成人| 欧美一区二区女人| 91久久精品国产91久久性色tv| 欧美国产精品日韩| 欧美性jizz18性欧美| 亚洲欧美日韩另类| 亚洲网站在线看| 日韩天天综合| **欧美日韩vr在线| 久久亚洲精选| 日韩小视频在线观看专区| 亚洲美女黄色片| 国产在线观看精品一区二区三区 | 午夜精品婷婷| 久久最新视频| 一本久道久久久| 最新亚洲视频| 国产精品久久999| 亚洲精品乱码久久久久久黑人| 国产精品毛片大码女人| 欧美日韩美女| 亚洲尤物精选| 亚洲午夜久久久久久久久电影院|