黑白棋游戏程序

#include <iostream>
#include<stdio.h>
#include <ctype.h>
#include <time.h>
#include <string.h>
#include <windows.h>
using namespace std;


int qi[8][8];
#define SIZE 8


void display(char board[][SIZE])
{
    int row=0;
    int col=0;
    char col_label='a';
    printf("\n ");
    for(col=0;col<SIZE;col++)
        printf("   %c",col_label+col);
    printf("\n");


    for(row=0;row<SIZE;row++)
    {
        printf("  +");
        for(col=0;col<SIZE;col++)
            printf("---+");
        printf("\n%2d|",row+1);


        for(col=0;col<SIZE;col++)
            printf(" %c |",board[row][col]);
        printf("\n");
    }


    printf("  +");
    for(col=0;col<SIZE;col++)
    printf("---+");
    printf("\n");
}//布置棋盘


int valid_moves(char board[][SIZE],int moves[][SIZE],char player)//查找
{
    int rowdelta=0;
    int coldelta=0;
    int row=0;
    int col=0;
    int x=0;
    int y=0;
    int no_of_moves=0;
    char opponent=(player=='o')?'*':'o';//player与opponent符号不同
    for(row=0;row<SIZE;row++)
    for(col=0;col<SIZE;col++)
        moves[row][col]=0;
    for(row=0;row<SIZE;row++)
        for(col=0;col<SIZE;col++)//查找棋盘上所有player可以下的地方
        {
            if(board[row][col]!=' ')
            continue;
            for(rowdelta=-1;rowdelta<=1;rowdelta++)
                for(coldelta=-1;coldelta<=1;coldelta++)//查找周围8个方向
                {
                    if(row+rowdelta<0||row+rowdelta>=SIZE||
                        col+coldelta<0||col+coldelta>=SIZE||
                        (rowdelta==0&&coldelta==0))
                    continue;
                    if(board[row+rowdelta][col+coldelta]==opponent)//与player不同的符号找到了
                    {
                        x=row+rowdelta;
                        y=col+coldelta;
                        for(;;)//接着判定往下的方向
                        {
                            x+=rowdelta;
                            y+=coldelta;
                            if(x<0||x>=SIZE||y<0||y>=SIZE)
                                break;
                            if(board[x][y]==' ')
                                break;
                            if(board[x][y]==player)//有player符号满足条件,player可以下
                            {
                                moves[row][col]=1;//查找全部可以下的地方并变为1
                                no_of_moves++;
                                break;
                            }
                        }
                    }
                }
        }
    return no_of_moves;
}


void make_move(char board[][SIZE],int row,int col,char player)//改变棋子
{
    int rowdelta=0;
    int coldelta=0;
    int x=0;
    int y=0;
    char opponent=(player=='o')?'*':'o';
    board[row][col]=player;
    for(rowdelta=-1;rowdelta<=1;rowdelta++)//查找棋子8个方向
        for(coldelta=-1;coldelta<=1;coldelta++)
        {
            if(row+rowdelta<0||row+rowdelta>=SIZE||
                col+coldelta<0||col+coldelta>=SIZE||
                (rowdelta==0&&coldelta==0))
            continue;
            if(board[row+rowdelta][col+coldelta]==opponent)
            {
                x=row+rowdelta;
                y=col+coldelta;


                for(;;)
                {
                    x+=rowdelta;
                    y+=coldelta;
                    if(x<0||x>=SIZE||y<0||y>=SIZE)
                        break;
                    if(board[x][y]==' ')
                        break;
                    if(board[x][y]==player)
                    {
                        while(board[x-=rowdelta][y-=coldelt
  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值