●UVa 1589 Xiangqi(模拟)
2024-10-18 16:03:17
●赘述题意
给出一个中国象棋残局,告诉各个棋子的位置,黑方只有1枚“将”,红方有至少2枚,至多7枚棋子,包含1枚“帅G”,和若干枚“车R”,“马H”,“炮C”。当前为黑方的回合,问黑方的“将”能否在移动一步后不被“将军”。
●题解
本题就是一个模拟:枚举“将”向四个方向走,是否满足题意。
但比较考察逻辑和代码能力。
但有一个坑点:
“将”在移动时,不能移动到与“帅”照面。
但,恶心的数据会有输入的局面就出现将帅照面的情况,按理说,应是黑方赢了(因为轮到黑方的回合),也就是说在程序中加一个特判。但不需要这么做,或者说:不需要我们这样处理,黑“将”不能在这种情况下直接向“帅”“开大炮”…
●代码(没用网上的二维数组的方法,是直接枚举红棋判断)
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
const int mv[4][2]={{1,0},{0,1},{-1,0},{0,-1}};
const int hv[8][2]={{-2,1},{-1,2},{1,2},{2,1},{2,-1},{1,-2},{-1,-2},{-2,-1}};
const int hp[8][2]={{-1,0},{0,1},{0,1},{1,0},{1,0},{0,-1},{0,-1},{-1,0}};
struct node{
char ch;
int x,y;
}a[10];
int n;
int abs(int x)
{
return x>0?x:-x;
}
bool eat(int bx,int by,int p)
{
return bx==a[p].x&&by==a[p].y;
}
bool CRkill(int bx,int by,int p,int t)
{
if(a[p].x!=bx&&a[p].y!=by) return 0;
int fg=a[p].y==by,l,r,cnt=0;
if(!fg) l=min(a[p].y,by),r=max(a[p].y,by);
else l=min(a[p].x,bx),r=max(a[p].x,bx);
for(int i=1;i<=n;i++) if(i!=p&&!eat(bx,by,i))
{
if(!fg&&a[i].x==bx&&l<a[i].y&&a[i].y<r) cnt++;
if(fg&&a[i].y==by&&l<a[i].x&&a[i].x<r) cnt++;
}
return cnt==t;
}
bool Hkill(int bx,int by,int p)
{
if(abs(bx-a[p].x)*abs(by-a[p].y)!=2) return 0;
int fx,fy;
for(int i=0;i<8;i++)
{
fx=a[p].x+hv[i][0];
fy=a[p].y+hv[i][1];
if(fx==bx&&fy==by)
{
bool fg=1;
for(int j=1;j<=n;j++) if(j!=p&&!eat(bx,by,j))
if(a[j].x==a[p].x+hp[i][0]&&a[j].y==a[p].y+hp[i][1]) fg=0;
if(fg) return 1;
}
}
return 0;
}
bool live(int bx,int by)
{
for(int i=1;i<=n;i++) if(!eat(bx,by,i))
{
if(a[i].ch=='G'&&CRkill(bx,by,i,0)) return 0;
if(a[i].ch=='R'&&CRkill(bx,by,i,0)) return 0;
if(a[i].ch=='C'&&CRkill(bx,by,i,1)) return 0;
if(a[i].ch=='H'&&Hkill(bx,by,i)) return 0;
}
return 1;
}
bool check(int bx,int by)
{
int fx,fy;
for(int i=0;i<4;i++)
{
fx=bx+mv[i][0];
fy=by+mv[i][1];
if(fx<1||fx>3||fy<4||fy>6) continue;
if(live(fx,fy)) return 0;
}
return 1;
}
int main()
{
int bx,by;
while(1)
{
cin>>n>>bx>>by;
if(!n&&!bx&&!by) break;
for(int i=1;i<=n;i++)
cin>>a[i].ch>>a[i].x>>a[i].y;
if(check(bx,by)) cout<<"YES"<<endl;
else cout<<"NO"<<endl;
}
return 0;
}
最新文章
- 常见端口 HTTP代码
- gulp安装说明
- STM32学习笔记——点亮LED
- 什么是REST、RESTful
- Ioc正解
- java命令行参数
- BLOB:大数据,大对象,在数据库中用来存储超长文本的数据,例如图片等
- 一个构建XML对象的js库
- 视频播放-VideoVIew,Vitamio
- (转载)php的类中可以不定义成员变量,直接在构造方法中使用并赋值吗?
- stl之map 排序
- OpenJDK 阅读源代码 Java 实现字节流输入类
- LNMP 快速安装
- 【LeetCode每天一题】4Sum(4数之和)
- MySQL_插入更新 ON DUPLICATE KEY UPDATE
- 使用pull方式解析xml文件示例:
- v-bind、v-on 的缩写
- Ubuntu root 密码忘记-恢复
- 【LeetCode】96. Unique Binary Search Trees (2 solutions)
- pipe_wait问题_转
热门文章
- 团队作业5-测试与发布(AIpha版本)
- 《Language Implementation Patterns》之 增强解析模式
- python虚拟环境搭建大全(转)
- jsMath对象
- BizTalk Server 2010高可用方案
- ajax中设置contentType: “application/json”的作用
- angluarjs2入门学习资源
- 开源软件:NoSql数据库 - 图数据库 Cassandra
- 使用Java High Level REST Client操作elasticsearch
- python flask框架 蓝图的使用