当前仓库属于暂停状态,部分功能使用受限,详情请查阅 仓库状态说明
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
removeChess.c 2.83 KB
一键复制 编辑 原始数据 按行查看 历史
#include"chessApi.h"
#include <stdio.h>
#include <string.h>
enum
{
NO_DIR,
TOP,
DOWN,
LEFT,
RIGHT
};
#define for_each_chess(row,col) \
for (int row=0; row< ROWS; row++) \
for(int col=0;col<COLS; col++)
BOOL nearSpace(int row, int col, int role);
BOOL nextIsSpace(int row, int col);
//当一方下了一子后,可能要提走另外一方的一些棋子,本函数处理这个逻辑
//判断棋盘上角色为role的棋子是否需要提走,如果需要,则提走
//最后2个参数用于记录本次提走的最后一颗棋子的位置
//返回提走的棋子数目
int removeChesses(int role, int *removeRow, int *removeCol)
{
int life[ROWS][COLS];
int count = 0;
for_each_chess(row,col)
life[row][col] = 1; //全部初始化为有生命
for_each_chess(row,col)
if(role == chessBoard[row][col]) {
if(!nearSpaceApi(row,col,role)) {
life[row][col] = 0;
//附近找不到空白,此棋无生命了
}
}
for_each_chess(row,col)
if(life[row][col] == 0) {
*removeRow = row;
*removeCol = col;
chessBoard[row][col]=EMPTY; //把无生命的棋子移除
count++;
}
return count;
}
int traverseData[ROWS][COLS]; //主要用于记录那些位置已经判断过是否附近有空格了,防止递归死循环
//附近是否有空白位置,如果一个空白位置都没有找到,那么说明这一片棋已经无气了
//row, col为当前棋子的位置,role为当前棋子的角色,exceptdir为排除的方向
BOOL nearSpace(int row, int col, int role)
{
//当前棋子的相邻位置为空白,则有气-生命
if (nextIsSpace(row,col)) {
return TRUE;
}
traverseData[row][col] = role; // 这个位置暂时记录一下,递归过程中,不就要再来处理了
BOOL res = FALSE;
if (row > 0 && traverseData[row-1][col] != role && chessBoard[row-1][col] == role)
res |= nearSpace(row-1,col,role);
if (row < ROWS-1 && traverseData[row+1][col] != role && chessBoard[row+1][col] == role)
res |= nearSpace(row+1,col,role);
if (col > 0 && traverseData[row][col-1] != role && chessBoard[row][col-1] == role)
res |= nearSpace(row,col-1,role);
if (col < COLS-1 && traverseData[row][col+1] != role && chessBoard[row][col+1] == role)
res |= nearSpace(row,col+1,role);
return res;
}
BOOL nextIsSpace(int row, int col)
{
if (row > 0 && chessBoard[row-1][col] == EMPTY)
return TRUE; //上方空白
if (col > 0 && chessBoard[row][col-1] == EMPTY)
return TRUE; //左方空白
if (row < ROWS-1 && chessBoard[row+1][col] == EMPTY)
return TRUE; //下方空白
if (col < COLS-1 && chessBoard[row][col+1] == EMPTY)
return TRUE; //右方空白
return FALSE;
}
//给其它模块使用
BOOL nearSpaceApi(int row, int col, int role)
{
memset(traverseData,0,sizeof(traverseData));
return nearSpace(row,col,role);
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化