UVa1589 象棋
就是声明两个数组,一个模拟棋局,另一个模拟黑将不能走的位置。不过写得有点长了...
#include<iostream>
#include<string>
using namespace std;
struct Node
{
];
int x, y;
}a[];
][]; //模拟棋盘棋子的情况
][]; //模拟黑棋不能走的情况
int bh, bs; //黑色棋子的坐标
void G(int x, int y) //模拟帅棋子
{
;
; i < x; i++)
{
if (vis[i][y])
{
flag = ;
break;
}
}
)
{
cnt[][y] = ;
cnt[][y] = ;
cnt[][y] = ;
}
}
void R(int x, int y) //模拟车棋子
{
;
&& y < )
{
; i < ; i++)
{
if (vis[x][i])
{
flag = ;
break;
}
}
}
&& y>)
{
; i < y; i++)
{
if (vis[x][i])
{
flag = ;
break;
}
}
}
&& y <= )
{
; i < y; i++)
{
if (vis[i][y])
{
flag = ;
break;
}
}
}
)
{
)
{
cnt[x][] = ;
cnt[x][] = ;
cnt[x][] = ;
}
)
{
cnt[][y] = ;
cnt[][y] = ;
cnt[][y] = ;
}
}
}
void C(int x, int y) //模拟炮棋子
{
;
&& y < )
{
; i < ; i++)
{
if (vis[x][i])
{
cnt[x][] = ;
cnt[x][] = ;
cnt[x][] = ;
break;
}
}
}
&& y > )
{
; i < y; i++)
{
if (vis[x][i])
{
cnt[x][] = ;
cnt[x][] = ;
cnt[x][] = ;
}
}
}
&& y >= && y <= )
{
; i < x; i++)
{
if (vis[i][y])
{
cnt[][y] = ;
cnt[][y] = ;
cnt[][y] = ;
}
}
}
}
void H(int x, int y) //模拟马棋子
{
> )
{
][y])
{
> )
{
cnt[x - ][y - ] = ;
}
< )
{
cnt[x + ][y + ] = ;
}
}
}
< )
{
][y])
{
> )
{
cnt[x + ][y - ] = ;
}
< )
{
cnt[x + ][y + ] = ;
}
}
}
> )
{
])
{
> )
{
cnt[x - ][y - ] = ;
}
< )
{
cnt[x + ][y - ] = ;
}
}
}
< )
{
])
{
> )
{
cnt[x - ][y + ] = ;
}
< )
{
cnt[x + ][y + ] = ;
}
}
}
}
int _tmain(int argc, _TCHAR* argv[])
{
int n; //红色棋子的个数
while (cin >> n >> bh >> bs && n)
{
memset(vis, , sizeof(vis));
memset(cnt, , sizeof(cnt));
; i < n; i++)
{
cin >> a[i].ch >> a[i].x >> a[i].y;
vis[a[i].x][a[i].y] = ;
}
; i < n; i++)
{
] == 'G') G(a[i].x, a[i].y);
] == 'R') R(a[i].x, a[i].y);
] == 'C') C(a[i].x, a[i].y);
] == 'H') H(a[i].x, a[i].y);
}
;
>)
{
][bs])
flag = ;
}
< )
{
][bs])
flag = ;
}
> )
{
])
flag = ;
}
< )
{
])
flag = ;
}
)
cout << "NO" << endl;
else
cout << "YES" << endl;
cout << endl;
}
;
}
UVa1589 象棋的更多相关文章
- UVA-1589 象棋(模拟)
题目:(传送门) 给出一个象棋的残局,下一步是黑棋走,判断黑棋是不是被将死. 思路: 读完这个题,知道是一个模拟题,然后想到用两个二维数组来模拟棋盘,一个(mp数组)用来存残局,一个(res数组)用来 ...
- [算法竞赛入门经典] 象棋 ACM/ICPC Fuzhou 2011, UVa1589 较详细注释
Description: Xiangqi is one of the most popular two-player board games in China. The game represents ...
- 算法习题---4-1象棋(UVa1589)
一:题目 在黑方只有一个“将”的情况下,红方只有(车.马.炮)(可以多个).帅的情况下,判断黑方是否被将死 (一)题目详解 其中棋盘按照坐标方式表示,左上角为(,),列数最大9,行数最大10 G 表示 ...
- HTML5学习总结——canvas绘制象棋(canvas绘图)
一.HTML5学习总结——canvas绘制象棋 1.第一次:canvas绘制象棋(笨方法)示例代码: <!DOCTYPE html> <html> <head> & ...
- 局域网象棋游戏(C++实现,使用Socket,界面使用Win32,CodeBlocks+GCC编译)
目录 成果 运行效果图 过程 1. 首先的问题是下棋的两端应该是什么样的? 2. 接下来的问题是怎么表示,怎么存储? 3. 然后应该怎么通信呢? 代码 main.cpp chinese_chess.h ...
- 简单的c#winform象棋游戏(附带源码)
算法源自网络(网络源码连接:http://www.mycodes.net/161/6659.htm) 整体思路:用二维数组构建棋盘每一个数组元素封装为一个picturebox附带若干属性(例如:棋 ...
- BZOJ 1801中国象棋 DP
1801: [Ahoi2009]chess 中国象棋 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1426 Solved: 826[Submit][ ...
- C#中国象棋+游戏大厅 服务器 + 客户端源码
来源:www.ajerp.com/bbs C#中国象棋+游戏大厅 服务器 + 客户端源码 源码开源 C#版中国象棋(附游戏大厅) 基于前人大虾的修改版 主要用委托实现 服务器支持在线人数,大厅桌数的设 ...
- 中国象棋引擎的C#源代码
以前写的中国象棋引擎的C#源程序,可在VS2010中编译运行,由于个人精力有限,难以完成后续的开发工作,如果谁感兴趣,请关注微信公众号(“申龙斌的程序人生”,ID:slbGTD),发送后台消息“象棋引 ...
随机推荐
- 最大公约数——Program G
最大公约数 Description There is a hill with n holes around. The holes are signed from 0 to n-1. A rabbit ...
- 图像显示与加载——opencv(转)
cvLoadImage() 函数:IplImage* cvLoadImage("图像名称",参数): 函数作用:加载图片: 函数返回值:为IplImage结构体: 参数说明:参数值 ...
- ODI 12c 安装
软件下载地址: http://www.oracle.com/technetwork/middleware/data-integrator/downloads/index.html 下载这个版本: Or ...
- Mahout0.9的安装与测试
最近想实协同过滤的MR算法,但是网上查了一下,发现hadoop的生态系统中的Mahout的项目已经实现了相应的算法,因此想先尝试着实时这个mahout的使用及效果.要想用mahout必须要部署到had ...
- POJ 2887 Big String (块状数组)
题意:给一个字符串(<=1000000)和n个操作(<2000),每个操作可以在某个位置插入一个字符,或者查询该位置的字符.问查询结果. 思路:块状数组. 如果将原来的字符串都存在一起,每 ...
- jstl表达式替换某些字符
转自:http://www.yiibai.com/jsp/jstl_function_replace.html fn:replace() 函数替换一个字符串与另一个字符串的所有匹配. 语法 fn:re ...
- (转)深入浅出 iOS 之生命周期
原文:http://www.cocoachina.com/applenews/devnews/2011/0817/3129.html 深入浅出 iOS 之生命周期 发布于:2011-08-17 10: ...
- 2016 -1 - 3 省市联动demo
#import "ViewController.h" #import "CZProvinces.h" @interface ViewController ()& ...
- 数据结构 《6》----堆 ( Heap )
Practival Problems: a. Construct a Huffman code b. Compute the sum of a large set of floating point ...
- HDU 圆桌会议 - 数学题
圆桌 题意就是每分钟可以将相邻的两个人的位置互换一下 , 问你 ,几分钟可以将所有人的位置互换成 原先的 B 在A的右边 C在A的左边 , 换成现在的 C 在A 的右边 , B 在 A 的 ...