POJ 4001 xiangqi(模拟)

原题链接:

题意简述:黑方只有一个棋子,将。红方有四种棋子,现在红方已走一步,轮到黑方走了,请问黑方是否必败。

解题思路:黑方最多有四种走法,分别判断这四个位置上黑方是否会输,如果全都会输,则必败。

错误报告:这题需要注意不能用%c或者getchar()读入,因为数据似乎不标准,这样读会出错,保险的做法是将字符当作字符串读入。另外只需要考虑全面一点,就可以了,要仔细一点。

代码示例:

#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;

int n,rr,cc;
int gr,gc;
const int maxn = 15;
struct Node{
    int r,c;
    char type;
    bool flag;
}qizi[maxn];
int Map[15][15];
bool Read(){
    memset(Map,0,sizeof Map);
    scanf("%d%d%d",&n,&rr,&cc);
    if(n == 0 && rr == 0 && cc == 0)  return false;
    for(int i = 1;i <= n;i++){
        cin >>qizi[i].type>>qizi[i].r>>qizi[i].c;
        //scanf("%c%d%d",&qizi[i].type,&qizi[i].r,&qizi[i].c);
        qizi[i].flag = true;
        if(qizi[i].type == 'G') gr = qizi[i].r,gc = qizi[i].c;
        Map[qizi[i].r][qizi[i].c] = i;
        //printf("%c %d %d\n",qizi[i].type,qizi[i].r,qizi[i].c);
    }
    return true;
}
bool survival(int r,int c){
   // printf("%d %d\n",r,c);
    for(int j = 1;j <= n;j++){
        if(qizi[j].flag == false)   continue;
        char t = qizi[j].type;
        int xr = qizi[j].r;
        int xc = qizi[j].c;
       // printf("%c %d %d\n",t,xr,xc);
        if(t == 'G'){
            bool flag = true;
            for(int i = r+1;i < xr;i++)
                if(Map[i][c])   flag = false;
            if(flag && xc == c) return false;
        }else if(t == 'R'){
            bool flag = true;
            if(xc == c){
                for(int i = r+1;i < xr;i++)
                    if(Map[i][c] != 0){
                        flag = false;
                        break;
                    }
                for(int i = xr+1;i < r;i++)
                    if(Map[i][c] != 0){
                        flag = false;
                        break;
                    }
            }else if(xr == r){
                for(int i = c+1;i < xc;i++)
                    if(Map[r][i] != 0){
                        flag = false;
                        break;
                    }
                 for(int i = xc+1;i < c;i++)
                    if(Map[r][i] != 0){
                        flag = false;
                        break;
                    }
            }else flag = false;
            if(flag) return false;
        }
        else if(t == 'C'){
            if(xc == c){
                int cnt = 0;
                for(int i = r+1;i < xr;i++)
                    if(Map[i][c] != 0){
                        cnt++;
                    }
                for(int i = xr+1;i < r;i++)
                    if(Map[i][c] != 0){
                        cnt++;
                    }
                if(cnt == 1) return false;
            }else if(xr == r){
                int cnt = 0;
                for(int i = c+1;i < xc;i++)
                    if(Map[r][i] != 0){
                        cnt++;
                    }
                for(int i = xc+1;i < c;i++)
                    if(Map[r][i] != 0){
                        cnt++;
                    }
                if(cnt == 1) return false;
            }
        }else if(t == 'H'){
            if(xr - 2 > 0){
                if(Map[xr-1][xc] == 0){
                    if(xr - 2 == r && xc - 1 == c)  return false;
                    if(xr - 2 == r && xc + 1 == c)  return false;
                }
            }
            if(xr + 2 < 11){
                if(Map[xr+1][xc] == 0){
                    if(xr + 2 == r && xc - 1 == c)  return false;
                    if(xr + 2 == r && xc + 1 == c)  return false;
                }
            }
            if(xc - 2 > 0){
                if(Map[xr][xc-1] == 0){
                    if(xr + 1 == r && xc - 2 == c)  return false;
                    if(xr - 1 == r && xc - 2 == c)  return false;
                }
            }
            if(xc + 2 < 10){
                if(Map[xr][xc+1] == 0){
                    if(xr + 1 == r && xc + 2 == c)  return false;
                    if(xr - 1 == r && xc + 2 == c)  return false;
                }
            }
        }
    }
    return true;
}
void solve(){

    int dr[] = {1,0,-1,0};
    int dc[] = {0,1,0,-1};
    for(int i = 0;i < 4;i++){
        int tr = rr+dr[i];
        int tc = cc+dc[i];
        if(tr > 0 && tr < 4 && tc > 3 && tc < 7){
            if(Map[tr][tc]){
               qizi[Map[tr][tc]].flag = false;
            }
            if(survival(tr,tc)){
                puts("NO");
                return;
            }
            if(Map[tr][tc]){
               qizi[Map[tr][tc]].flag = true;
            }
        }
    }
    puts("YES");
    return;
}
int main()
{
    while(Read()){
        solve();
    }
    return 0;
}

 

posted @ 2019-01-24 13:57  Dr_Lo  阅读(147)  评论(0编辑  收藏  举报