UVa 1589 Xiangqi
2016-04-10 21:38
288 查看
花了好长时间终于AC..... . 思路:将横竖看一看,再看看马,再上下左右走一走再判断一次
主要考虑特殊数据 马能不能走,还有将可以吃旁边的
2 1 4
H 2 2
H 2 6
4 2 5
R 3 5
G 10 4
C 5 5
R 2 9
主要考虑特殊数据 马能不能走,还有将可以吃旁边的
2 1 4
H 2 2
H 2 6
4 2 5
R 3 5
G 10 4
C 5 5
R 2 9
#include <iostream> #include <cstring> #include <cstdio> #include <cmath> using namespace std; char XQ[11][11]; int IsCheck(int x,int y); //判断将在该位置是不是被将军 int main() { int N; int gx,gy; while(scanf("%d%d%d",&N,&gx,&gy)&&N) { memset(XQ,0,sizeof(XQ)); while(N--) { int x,y; char ch; scanf("\n%c%d%d",&ch,&x,&y); XQ[x][y]=ch; } int ok=IsCheck(gx,gy); int dx[]={1,-1,0,0}; int dy[]={0,0,1,-1}; if(!ok) for(int i=0;i<4;i++) //上下左右走一走 { if(gx+dx[i]>=1&&gx+dx[i]<=3 &&gy+dy[i]>=4&&gy+dy[i]<=6&& IsCheck(gx+dx[i],gy+dy[i])) { ok=1; break; } } printf("%s\n",!ok?"YES":"NO"); } } int IsCheck(int x,int y) { for(int i=x+1,cnt=0;i<=10;i++) //考虑将的下面 { if(XQ[i][y]=='C'&&cnt==1) return 0; if(XQ[i][y]=='R'&&cnt==0) return 0; if(XQ[i][y]=='G'&&cnt==0) return 0; if(XQ[i][y]) cnt++; } for(int i=x-1,cnt=0;i>=1;i--) <span style="font-family: Arial, Helvetica, sans-serif;">//考虑将的上面</span> { if(XQ[i][y]=='C'&&cnt==1) return 0; if(XQ[i][y]=='R'&&cnt==0) return 0; if(XQ[i][y]=='G'&&cnt==0) return 0; if(XQ[i][y]) cnt++; } for(int j=y+1,cnt=0;j<=9;j++) <span style="font-family: Arial, Helvetica, sans-serif;">//考虑将的右边</span> { if(XQ[x][j]=='C'&&cnt==1) return 0; if(XQ[x][j]=='R'&&cnt==0) return 0; if(XQ[x][j]) cnt++; } for(int j=y-1,cnt=0;j>=1;j--) <span style="font-family: Arial, Helvetica, sans-serif;">//考虑将的左边</span> { if(XQ[x][j]=='C'&&cnt==1) return 0; if(XQ[x][j]=='R'&&cnt==0) return 0; if(XQ[x][j]) cnt++; } for(int i=x-2;i<=x+2;i++) //考虑马 for(int j=y-2;j<=y+2;j++) { if(i<1||j<1) continue; if(XQ[i][j]=='H'&&abs(x-i)+abs(y-j)==3) { if(j>y){ if(i>x&&!XQ[x+1][y+1]) return 0; if(i<x&&!XQ[x-1][y+1]) return 0; } else{ if(i>x&&!XQ[x+1][y-1]) return 0; if(i<x&&!XQ[x-1][y-1]) return 0; } } } return 1; }
相关文章推荐
- Windows 下基于 Eclipse 的可视化远程 Linux 开发环境搭建
- Linux内核如何装载和启动一个可执行程序
- iOS开发之 用第三方类库实现ScrollView
- raspberry pi使用vsftpd搭建ftp服务器
- 设计模式-4-装饰者模式
- 设计模式-3-工厂方法和抽象工厂模式
- 【Asp.net】初识
- 2016.4.10 线段树练习
- 20145120 《Java程序设计》第6周学习总结
- Atitit.跨语言异常转换机制 java c# php到js的异常转换
- [整理+原创]ubuntu Thunderbird Mail设置自动提醒
- Atitit.跨语言异常转换机制 java c# php到js的异常转换
- 组合数学 随记
- su和sudo命令
- 剑指Offer--008-旋转数组的最小数字
- jQuery点击按钮实现div的隐藏和显示切换效果
- 输出1-100之间的奇数
- struts2环境配置
- 手机抓包-fiddler
- Atitit.跨语言异常转换机制 java c# php到js的异常转换