模拟题考验coding能力,一定要思路清晰,按照模块化思想,有哪些情况,需要哪些功能都要事先分析好了。高手的模拟题代码往往结构很清晰,功能模块写成函数,没有过多重复代码,让人一看便明。

方法选择的好坏会影响编程复杂度,这题老将最多只能往四个位置走,就枚举这四个位置,每个位置再枚举每个红子看是不是有子能吃了它。枚举时注意有可能老将这一步吃了一个红子。

有一种情况是一开始双方老将就见面,这其实不叫红棋在将军,实际中红棋不能这么将。但是毕竟是一道编程题,出题人可能也不是太懂棋。。。所以要考虑这种情况。

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<string>
#include<cmath>
#include<map>
#include<set>
#include<vector>
#include<algorithm>
#include<stack>
#include<queue>
#include<cctype>
#include<sstream>
using namespace std;
#define pii pair<int,int>
#define LL long long int
const int eps=1e-;
const int INF=;
const int maxn=+;
int n,X,Y;
int maps[][];
int dx[]= {,-,,};
int dy[]= {,,,-};
struct Red
{
char type;
int x,y;
} red[];
bool can_eat(int r,int a,int b)
{
int x=red[r].x;
int y=red[r].y;
if(x==a&&y==b) return false;//老将吃掉了这个子
else if(red[r].type=='G')
{
if(y!=b) return false;//老将不碰面
for(int i=min(a,x)+; i<max(a,x); i++)
{
if(maps[i][b]) return false;//中间隔了子,老将不能碰面
}
return true;
}
else if(red[r].type=='R')
{
if((x!=a)&&(y!=b)) return false;
else if(x==a)
{
for(int i=min(y,b)+; i<max(y,b); i++)
{
if(maps[x][i]) return false;
}
return true;
}
else if(y==b)
{
for(int i=min(x,a)+; i<max(x,a); i++)
{
if(maps[i][y]) return false;
}
return true;
}
}
else if(red[r].type=='C')
{
if((x!=a)&&(y!=b)) return false;
else if(x==a)
{
int num=;
for(int i=min(y,b)+; i<max(y,b); i++)
{
if(maps[x][i]) num++;
}
if(num==) return true;
return false;
}
else if(y==b)
{
int num=;
for(int i=min(x,a)+; i<max(x,a); i++)
{
if(maps[i][y]) num++;
}
if(num==) return true;
return false;
}
}
else //red[r].type=='H'
{
if(x+==a&&y+==b&&maps[x+][y]=='\0') return true;
if(x+==a&&y+==b&&maps[x][y+]=='\0') return true;
if(x-==a&&y+==b&&maps[x-][y]=='\0') return true;
if(x-==a&&y+==b&&maps[x][y+]=='\0') return true;
if(x-==a&&y-==b&&maps[x-][y]=='\0') return true;
if(x-==a&&y-==b&&maps[x][y-]=='\0') return true;
if(x+==a&&y-==b&&maps[x+][y]=='\0') return true;
if(x+==a&&y-==b&&maps[x][y-]=='\0') return true;
return false;
}
}
bool pan();
int main()
{
//freopen("in8.txt","r",stdin);
//freopen("out.txt","w",stdout);
while(cin>>n>>X>>Y)
{
if(n==&&X==&&Y==) break;
int num,tx,ty;
memset(maps,,sizeof(maps));
bool ans=true;
for(num=; num<n; num++)
{
cin>>red[num].type>>red[num].x>>red[num].y;
maps[red[num].x][red[num].y]=;
}
if(pan())
{
puts("NO");
continue;
}
for(int i=; i<; i++)
{
tx=X+dx[i];
ty=Y+dy[i];
if(tx>=&&tx<=&&ty>=&&ty<=)//该步移动合法
{
bool capture=false;
for(int j=; j<n; j++) //检查现在有没有红子能吃黑将
{
if(can_eat(j,tx,ty))
{
capture=true;
break;
}
}
if(capture==true) continue;
else
{
ans=false;
break;
}
}
else continue;
}
if(ans==false) printf("NO\n");
else printf("YES\n");
}
//fclose(stdin);
//fclose(stdout);
return ;
}
bool pan()
{
for(int i=; i<n; i++)
{
if(red[i].type=='G')
{
if(Y==red[i].y)
{
for(int j=min(red[i].x,X)+; j<max(red[i].x,X); j++)
{
if(maps[j][Y])
{
return false;
}
}
}
else
{
return false;
}
}
}
return true;
}

hdu4121 poj4001 Xiangqi(模拟)的更多相关文章

  1. HDU 4121 Xiangqi 模拟题

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

  2. TZOJ 4746 Xiangqi(模拟棋盘数组)

    描述 Xiangqi is one of the most popular two-player board games in China. The game represents a battle ...

  3. HDU 4121 Xiangqi --模拟

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

  4. UVA 1589:Xiangqi (模拟 Grade D)

    题目: 象棋,黑棋只有将,红棋有帅车马炮.问是否死将. 思路: 对方将四个方向走一步,看看会不会被吃. 代码: 很难看……WA了很多发,还越界等等. #include <cstdio> # ...

  5. dir命令只显示文件名

    dir /b 就是ls -f的效果 1057 -- FILE MAPPING_web_archive.7z 2007 多校模拟 - Google Search_web_archive.7z 2083 ...

  6. Xiangqi(简单模拟)

    4746: Xiangqi 时间限制(普通/Java):1000MS/3000MS     内存限制:65536KByte 总提交: 15            测试通过:2 描述 Xiangqi i ...

  7. BFS、模拟:UVa1589/POJ4001/hdu4121-Xiangqi

    Xiangqi Xiangqi is one of the most popular two-player board games in China. The game represents a ba ...

  8. ●UVa 1589 Xiangqi(模拟)

    ●赘述题意 给出一个中国象棋残局,告诉各个棋子的位置,黑方只有1枚“将”,红方有至少2枚,至多7枚棋子,包含1枚“帅G”,和若干枚“车R”,“马H”,“炮C”.当前为黑方的回合,问黑方的“将”能否在移 ...

  9. HDU 4121 Xiangqi (算是模拟吧)

    传送门:http://acm.hdu.edu.cn/showproblem.php?pid=4121 题意:中国象棋对决,黑棋只有一个将,红棋有一个帅和不定个车 马 炮冰给定位置,这时当黑棋走,问你黑 ...

随机推荐

  1. zabbix3.2.4监控MySQL5.7.16状态

    一.添加监控用户mysql> grant all privileges on *.* to 'zabbix'@'localhost' identified by 'zabbix';mysql&g ...

  2. 剑指offer 面试36题

    面试36题: 题:二叉搜索树与双向链表 题目:输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树中结点指针的指向. 解题思路一:由于输入的一个二叉搜索树, ...

  3. jquery 字符串转为json

    使用ajax从服务器拿到的数据,jquery总是认为是字符串,无法直接使用,可以通过下面代码转换: $.get("服务器路径", function(data) { data = e ...

  4. asp.net IRequiresSessionState

    在一般处理程序中,使用context.Session对象,必须先继承IRequiresSessionState接口. System.Web.SessionState.IRequiresSessionS ...

  5. [SCOI2005]超级格雷码

    题目 BZOJ 洛谷 做法 爆搜真有意思 满足不重复且异或后仅一位为\(1\) 利用奇偶性交叉搜索(仅改变一位) My complete code #include<bits/stdc++.h& ...

  6. 4.2《深入理解计算机系统》笔记(五)并发、多进程和多线程【Final】

    该书中第11章是写web服务器的搭建,无奈对web还比较陌生.还没有搞明白. 这些所谓的并发,其实都是操作系统做的事情,比如,多进程是操作系统fork函数实现的.I/O多路复用需要内核挂起进程.多线程 ...

  7. IEnumerable的一些基本方法 补充

    接上一篇,我们发现两表连接方式默认为内连接,而我们在SQL中常用到的左连接没有封装方法.换句话说,微软放弃两表左连或右连的这种做法(只有在2个表都存在值时,这样的连接才有意义). 如果要实现表的左连接 ...

  8. poj 1703 Find them, Catch them 【并查集 新写法的思路】

    题目地址:http://poj.org/problem?id=1703 Sample Input 1 5 5 A 1 2 D 1 2 A 1 2 D 2 4 A 1 4 Sample Output N ...

  9. eclipse maven 项目 maven build 无反应

    eclipse maven 项目 使用maven build ,clean 等命令均无反应,控制台无任何输出 1.打开Window --> Preferences --> Java --& ...

  10. Luogu-1527 [国家集训队]矩阵乘法

    Luogu-1527 [国家集训队]矩阵乘法 题面 Luogu-1527 题解 昨天学CDQ分治时做了一些题,但是因为题(wo)太(tai)水(lan)了(le)并没有整理 学了一晚上的整体二分,拿这 ...