传送门:http://acm.hdu.edu.cn/showproblem.php?pid=4121

题意:中国象棋对决,黑棋只有一个将,红棋有一个帅和不定个车 马 炮冰给定位置,这时当黑棋走,问你黑棋是不是被将死了(当前位置被将,能走得下一步也被将)

题解:代码里面注释很详细,我就不多说了,知道象棋规则的同学基本上都可以做出来

AC代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <cstdlib>
#include <cmath>
#include <vector>
#include <list>
#include <deque>
#include <queue>
#include <iterator>
#include <stack>
#include <map>
#include <set>
#include <algorithm>
#include <cctype>
using namespace std; #define si1(a) scanf("%d",&a)
#define si2(a,b) scanf("%d%d",&a,&b)
#define sd1(a) scanf("%lf",&a)
#define sd2(a,b) scanf("%lf%lf",&a,&b)
#define ss1(s) scanf("%s",s)
#define pi1(a) printf("%d\n",a)
#define pi2(a,b) printf("%d %d\n",a,b)
#define mset(a,b) memset(a,b,sizeof(a))
#define forb(i,a,b) for(int i=a;i<b;i++)
#define ford(i,a,b) for(int i=a;i<=b;i++) typedef long long LL;
const int N=110001;
const int M=1000007;
const int INF=0x3f3f3f3f;
const double PI=acos(-1.0);
const double eps=1e-7; char mp[11][11];
int bx,by,n;
int tt[4][2]={1,0,-1,0,0,1,0,-1}; struct node
{
int x,y;
}pp[11]; bool shu(int x1,int x2,int y)
{
if(x1>x2) swap(x1,x2);
int f=0;
for(int i=x1+1;i<x2;i++)
if(mp[i][y]!='0')
f=1;
if(f) return false;
else return true;
} bool heng(int x,int y1,int y2)
{
if(y1>y2) swap(y1,y2);
int f=0;
for(int j=y1+1;j<y2;j++)
if(mp[x][j]!='0')
f=1;
if(f) return false;
else return true;
} bool shuone(int x1,int x2,int y)
{
if(x1>x2) swap(x1,x2);
int f=0;
for(int i=x1+1;i<x2;i++)
if(mp[i][y]!='0')
f++;
if(f!=1) return false;
else return true;
} bool hengone(int x,int y1,int y2)
{
if(y1>y2) swap(y1,y2);
int f=0;
for(int j=y1+1;j<y2;j++)
if(mp[x][j]!='0')
f++;
if(f!=1) return false;
else return true;
} bool jiang(int x,int y)
{
forb(i,0,n)
{
int rx=pp[i].x,ry=pp[i].y;
char c=mp[rx][ry];
if(c=='G')//对将的时候,判断在一列且中间没有棋子
{
if(ry==y&&shu(x,rx,y)) return true;
}
if(c=='R')//车,判断在一行一列且中间没有棋子
{
if(x==rx&&heng(x,y,ry)) return true;
if(y==ry&&shu(x,rx,y)) return true;
}
if(c=='H')//马,判断距离为3,且没有被撇马腿
{
if((abs(x-rx)+abs(y-ry))!=3) continue;
if(abs(x-rx)==2)
{
if(rx<x&&mp[rx+1][ry]=='0') return true;
if(rx>x&&mp[rx-1][ry]=='0') return true;
}
if(abs(y-ry)==2)
{
if(ry<y&&mp[rx][ry+1]=='0') return true;
if(ry>y&&mp[rx][ry-1]=='0') return true;
}
}
if(c=='C')//炮,判断在一行一列且中间只有一个棋子
{
if(x==rx&&hengone(x,y,ry)) return true;
if(y==ry&&shuone(x,rx,y)) return true;
}
}
return false;
} int main()
{
while(scanf("%d%d%d",&n,&bx,&by)&&(n+bx+by)!=0)
{
memset(mp,'0',sizeof(mp));
char c;
int x,y;
forb(i,0,n)
{
cin>>c>>x>>y;
mp[x][y]=c;
pp[i].x=x; pp[i].y=y;
} if(!jiang(bx,by))//如果开始的时候都不将军则直接输出no
{
printf("NO\n");
continue;
}
int flag=0;
forb(i,0,4)//可以向四个方向走
{
x=bx+tt[i][0];
y=by+tt[i][1];
if(x>=1&&x<=3&&y>=4&&y<=6)//注意范围
{
char c=mp[x][y];//这个地方要注意,如果有棋子的话可以吃,开始的时候我认为有棋子的地方不能走
mp[x][y]='0';
if(!jiang(x,y))//判断能不能将军
{
flag=1;
break;
}
mp[x][y]=c;//还原
}
}
printf("%s\n",flag?"NO":"YES");
}
return 0;
}

HDU 4121 Xiangqi (算是模拟吧)的更多相关文章

  1. HDU 4121 Xiangqi 模拟题

    Xiangqi Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=4121 ...

  2. HDU 4121 Xiangqi --模拟

    题意: 给一个象棋局势,问黑棋是否死棋了,黑棋只有一个将,红棋可能有2~7个棋,分别可能是车,马,炮以及帅. 解法: 开始写法是对每个棋子,都处理处他能吃的地方,赋为-1,然后判断将能不能走到非-1的 ...

  3. HDU 4121 Xiangqi

    模拟吧,算是... 被这个题wa到哭,真是什么都不想说了...上代码 #include <iostream> #include <cstring> using namespac ...

  4. HDU 4121 Xiangqi 我老了?

    Xiangqi Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  5. HDU 5510---Bazinga(指针模拟)

    题目链接 http://acm.hdu.edu.cn/search.php?action=listproblem Problem Description Ladies and gentlemen, p ...

  6. HDU 5047 Sawtooth(大数模拟)上海赛区网赛1006

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5047 解题报告:问一个“M”型可以把一个矩形的平面最多分割成多少块. 输入是有n个“M",现 ...

  7. HDU 5965 扫雷 【模拟】 (2016年中国大学生程序设计竞赛(合肥))

    扫雷 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submissi ...

  8. HDU 5935 Car 【模拟】 (2016年中国大学生程序设计竞赛(杭州))

    Car Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...

  9. HDU 5912 Fraction 【模拟】 (2016中国大学生程序设计竞赛(长春))

    Fraction Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Su ...

随机推荐

  1. exec与xargs区别

    区别描述: 两者都是对符合条件的文件执行所给的Linux 命令,而不询问用户是否需要执行该命令. -exec:{}表示命令的参数即为所找到的文件,以:表示comman命令的结束.\是转义符,因为分号在 ...

  2. c#编程:输入、输出

    c#编程 main函数 static void Main(string[] args)        {        } 程序需写在main函数的花括号内 一.输出:Console.WriteLin ...

  3. work staff

    培训一周,很抓狂.不是抓狂培训本身,是自己听不懂,培训还是有用的. 上周四接到一个task,关于checklist.因为组里没有人用过,所以遇到一些问题,本来不应该是一个复杂的工作,但是我需要一个一个 ...

  4. FineUI布局应用(二)

    一.FineUI页面布局分为 1.Fit布局 <f:Panel ID="Panel1" Title="布局Fit(Layout=Fit)" runat=& ...

  5. java NumberForMate的使用

    有时候我们需要将数字转化为字符串,并且转化后的长度要一定.比如00012这种类型.这时候我们就可以使用NumberForMate这个方法: NumberFormat numberFormat = Nu ...

  6. 作为java应届生,面试求职那点事

    找工作两星期多了.心情不爽,写点记录打发时间. 嘘~~自己的破事:  刚毕业,也过了实习,本理所应当的留在公司转正.可是为了谈了两年的女朋友回家见面.一切都顺利进行,妈妈也开心给了一万见面礼,一切都以 ...

  7. 客户Oracle数据库在插入数据的时候报超出最大长度的错误(规避风险)

    背景: 项目使用oracle数据,在开发环境测试一些正常.项目部署到客户的服务器上后,系统在添加数据的时候报错.输出错误信息,发现是“超出最大长度”的异常. 但是按照数据库的设计,添加的数据应该在允许 ...

  8. Oracle instr 及 like

    原文: http://www.cnblogs.com/crazyjava/archive/2012/10/31/2748202.html instr(string1,string2[,start_po ...

  9. 【3】创建一个简单的Laravel例子

    现在我们来创建一个Laravel的例子来帮助理解 1.首先打开app/Http/routes.php文件,在里边写上一条路由: 2.创建一个控制器,有两种方法 ①在app/Http/Controlle ...

  10. PHP命名空间(Namespace)的使用详解(转)

    对于命名空间,官方文档已经说得很详细[查看],我在这里做了一下实践和总结. 命名空间一个最明确的目的就是解决重名问题,PHP中不允许两个函数或者类出现相同的名字,否则会产生一个致命的错误.这种情况下只 ...