三子棋游戏

头文件:    game.h

#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<windows.h>
//游戏代码的声明(函数声明,符号定于)
#define ROW 3//棋盘的行数
#define LIN 3//棋盘的列数

void ceshi();

void meau();//打印游戏菜单

void game();//三子棋游戏逻辑的实现

void init_board(char board[ROW][LIN], int row, int lin);//初始化棋盘

//打印棋盘
void print_board(char board[ROW][LIN], int row, int lin);

//判断是否连成三子
//返回为1表示连成三子,返回0表示不成三子
int pan_duan(char board[ROW][LIN], int row, int lin);

//比较两个字符是否相等,相等返回1;不相等返回0
int bi_jiao(char a, char b);

//判断从改子往上数共n个数是否一样
int pan_duan_shang(char board[ROW][LIN], int i, int j, int n);

//判断从该子往下数共n个数是否一样
int pan_duan_xia(char board[ROW][LIN], int i, int j, int n);

//判断从该子往左数共n个数是否一样
int pan_duan_zuo(char board[ROW][LIN], int i, int j, int n);

//判断从该子往右数共n个数是否一样
int pan_duan_you(char board[ROW][LIN], int i, int j, int n);

//判断从该子往左上数共n个数是否一样
int pan_duan_zuoshang(char board[ROW][LIN], int i, int j, int n);

//判断从该子往左下数共n个数是否一样
int pan_duan_zuoxia(char board[ROW][LIN], int i, int j, int n);

//判断从该子往右上数共n个数是否一样
int pan_duan_youshang(char board[ROW][LIN], int i, int j, int n);

//判断从该子往右下数共n个数是否一样
int pan_duan_youxia(char board[ROW][LIN], int i, int j, int n);

//玩家下棋
void player(char board[ROW][LIN]);

//电脑下棋
void computer(char board[ROW][LIN]);
 

具体函数实现: game.c

#define _CRT_SECURE_NO_WARNINGS 
//游戏代码的实现
#include"game.h"

//测试数据
void ceshi()
{
    
}


//打印游戏菜单
void meau()
{
        printf("********************\n");
        printf("******1.play********\n");
        printf("******0.exit********\n");
        printf("********************\n");
}

//实现游戏的逻辑
void game()
{
    srand((unsigned int)time(NULL));
    char board[ROW][LIN] = { 0 };

    //初始化棋盘
    init_board(board, ROW, LIN);

    //打印初始化后的棋盘
    printf("初始棋盘如下:\n");
    print_board(board, ROW, LIN);

    //玩家开始游戏
    while (1)
    {
        //玩家下棋
        player(board);
        //下一次棋,显示一次棋盘
        print_board(board, ROW, LIN);
        //判断是否连成三子
        int c1 = pan_duan(board,ROW,LIN);
        if (c1 == 1)
        {
            printf("恭喜您!\n");
            break;
        }
        

        电脑下棋
        computer(board);
        下一次棋,显示一次棋盘
        print_board(board, ROW, LIN);
        //判断是否连成三子
        int c2 = pan_duan(board, ROW, LIN);
        if (c2 == 1)
        {
            printf("很遗憾!\n");
            break;
        }
    
    }
    //打印最终棋盘
    print_board(board, ROW, LIN);
}

//初始化棋盘
void init_board(char board[ROW][LIN], int row, int lin)
{
    int i = 0;
    int j = 0;
    for (i = 0; i < row; i++)
    {
        for (j = 0; j < lin; j++)
        {
            board[i][j] = ' ';
        }
    }
}

//打印棋盘
void print_board(char board[ROW][LIN], int row, int lin)
{
    int i = 0;
    int j = 0;
    //输出最上面的边框---------
    for (j = 0; j < lin; j++)
    {
        printf(" ---");
    }
    printf("\n");
    for (i = 0; i < row; i++)
    {
        for (j = 0; j < lin; j++)
        {
            printf("| %c ",board[i][j]);
            if (j == lin - 1)
            {
                printf("|");
            }
        }
        printf("\n");
        for (j = 0; j < lin; j++)
        {
            printf(" ---");
        }
        printf("\n");
    }
}

//判断从该子往上数共n个数是否一样
int pan_duan_shang(char board[ROW][LIN],int i,int j,int n)
{
    //首先判断此位置是是否为空,为空则不需要判断
    if (board[i][j] != ' ')
    {
        //判断从改子往上是否连成三子
        //先判断往上数是都由三个格子,没有则不需要判断
        if (i >= n - 1)
        {
            //三子需要判断三次,n子需要判断n-1次,当前位置与下一个位置进行比较
            int m = i;//用来控制判断次数
            for (m = i; m >= i - n + 2; m--)
            {
                if (m != i - n + 2)//还未比较到最后一位
                {
                    if (board[m][j] == board[m - 1][j])
                    {
                        continue;
                    }
                    else
                    {
                        return 0;
                    }
                }
                if (m == i - n + 2)//比较到最后一位时
                {
                    if (board[m][j] == board[m - 1][j])
                    {
                        return 1;
                    }
                    else
                    {
                        return 0;
                    }
                }
            }
        }
        else
        {
            return 0;
        }
    }
    else
    {
        return 0;
    }
}

//判断从该子往下数共n个数是否一样
int pan_duan_xia(char board[ROW][LIN], int i, int j, int n)
{
    //首先判断此位置是是否为空,为空则不需要判断
    if (board[i][j] != ' ')
    {
        //判断从改子往下是否连成三子
        //先判断往上数是都由三个格子,没有则不需要判断
        if (ROW - 1 - i >= n - 1)
        {
            //三子需要判断三次,n子需要判断n-1次,当前位置与下一个位置进行比较
            int m = i;//用来控制判断次数
            for (m = i; m <= i + n - 2; m++)
            {
                if (m != i + n - 2)//还未比较到最后一位
                {
                    if (board[m][j] == board[m + 1][j])
                    {
                        continue;//相同直接进行比较下一位
                    }
                    else
                    {
                        return 0;//不相同直接跳出不需要比较
                    }
                }
                if (m == i + n - 2)//比较到最后一位时
                {
                    if (board[m][j] == board[m + 1][j])
                    {
                        return 1;
                    }
                    else
                    {
                        return 0;
                    }
                }
            }
        }
        else
        {
            return 0;
        }
    }
    else
    {
        return 0;
    }
}

//判断从该子往左数共n个数是否一样
int pan_duan_zuo(char board[ROW][LIN], int i, int j, int n)
{
    //首先判断此位置是是否为空,为空则不需要判断
    if (board[i][j] != ' ')
    {
        //判断从改子往左是否连成三子
        //先判断往左数是否有三个格子,没有则不需要判断
        if (j >= n - 1)
        {
            //三子需要判断三次,n子需要判断n-1次,当前位置与下一个位置进行比较
            int m = j;//用来控制判断次数
            for (m = j; m >= j - n + 2; m--)
            {
                if (m != j - n + 2)//还未比较到最后一位
                {
                    if (board[i][m] == board[i][m-1])
                    {
                        continue;
                    }
                    else
                    {
                        return 0;
                    }
                }
                if (m == j - n + 2)//比较到最后一位时
                {
                    if (board[i][m] == board[i][m-1])
                    {
                        return 1;
                    }
                    else
                    {
                        return 0;
                    }
                }
            }
        }
        else
        {
            return 0;
        }
    }
    else
    {
        return 0;
    }
}

//判断从该子往右数共n个数是否一样
int pan_duan_you(char board[ROW][LIN], int i, int j, int n)
{
    //首先判断此位置是是否为空,为空则不需要判断
    if (board[i][j] != ' ')
    {
        //判断从改子往下是否连成三子
        //先判断往上数是都由三个格子,没有则不需要判断
        if (LIN -1 - j >= n - 1)
        {
            //三子需要判断三次,n子需要判断n-1次,当前位置与下一个位置进行比较
            int m = j;//用来控制判断次数
            for (m = j; m <= j + n - 2; m++)
            {
                if (m != j + n - 2)//还未比较到最后一位
                {
                    if (board[i][m] == board[i][m+1])
                    {
                        continue;//相同直接进行比较下一位
                    }
                    else
                    {
                        return 0;//不相同直接跳出不需要比较
                    }
                }
                if (m == j + n - 2)//比较到最后一位时
                {
                    if (board[i][m] == board[i][m + 1])
                    {
                        return 1;
                    }
                    else
                    {
                        return 0;
                    }
                }
            }
        }
        else
        {
            return 0;
        }
    }
    else
    {
        return 0;
    }
}

//判断从该子往左上数共n个数是否一样
int pan_duan_zuoshang(char board[ROW][LIN], int i, int j, int n)
{
    //首先判断此位置是是否为空,为空则不需要判断
    if (board[i][j] != ' ')
    {
        //判断从改子往上是否连成三子
        //先判断往上数是都由三个格子,没有则不需要判断
        if (i >= n - 1 && j >=n-1)
        {
            //三子需要判断三次,n子需要判断n-1次,当前位置与下一个位置进行比较
            int m = i;
            int z = j;//用来控制判断次数
            for (m = i,z = j; m >= i - n + 2,z >= j - n+2; m--,z--)
            {
                if (m != i - n + 2 && z!=j-n+2)//还未比较到最后一位
                {
                    if (board[m][z] == board[m - 1][z-1])
                    {
                        continue;
                    }
                    else
                    {
                        return 0;
                    }
                }
                if (m == i - n + 2 && z == j-n+2)//比较到最后一位时
                {
                    if (board[m][z] == board[m - 1][z-1])
                    {
                        return 1;
                    }
                    else
                    {
                        return 0;
                    }
                }
            }
        }
        else
        {
            return 0;
        }
    }
    else
    {
        return 0;
    }
}

//判断从该子往左下数共n个数是否一样
int pan_duan_zuoxia(char board[ROW][LIN], int i, int j, int n)
{
    //首先判断此位置是是否为空,为空则不需要判断
    if (board[i][j] != ' ')
    {
        //判断从改子往左下是否连成三子
        //先判断往左下数是都由三个格子,没有则不需要判断
        if (ROW - 1 -i >= n - 1 && j >= n - 1)
        {
            //三子需要判断三次,n子需要判断n-1次,当前位置与下一个位置进行比较
            int m = i;
            int z = j;//用来控制判断次数
            for (m = i, z = j; m <= i + n -2, z >= j - n + 2; m++, z--)
            {
                if (m != i + n - 2 && z != j - n + 2)//还未比较到最后一位
                {
                    if (board[m][z] == board[m + 1][z - 1])
                    {
                        continue;
                    }
                    else
                    {
                        return 0;
                    }
                }
                if (m == i + n - 2 && z == j - n + 2)//比较到最后一位时
                {
                    if (board[m][z] == board[m + 1][z - 1])
                    {
                        return 1;
                    }
                    else
                    {
                        return 0;
                    }
                }
            }
        }
        else
        {
            return 0;
        }
    }
    else
    {
        return 0;
    }
}

//判断从该子往右上数共n个数是否一样
int pan_duan_youshang(char board[ROW][LIN], int i, int j, int n)
{
    //首先判断此位置是是否为空,为空则不需要判断
    if (board[i][j] != ' ')
    {
        //判断从改子往左下是否连成三子
        //先判断往左下数是都由三个格子,没有则不需要判断
        if (i >= n - 1 && LIN-1-j >= n - 1)
        {
            //三子需要判断三次,n子需要判断n-1次,当前位置与下一个位置进行比较
            int m = i;
            int z = j;//用来控制判断次数
            for (m = i, z = j; m >= i - n + 2, z <= j + n - 2; m--, z++)
            {
                if (m != i - n + 2 && z != j + n - 2)//还未比较到最后一位
                {
                    if (board[m][z] == board[m - 1][z + 1])
                    {
                        continue;
                    }
                    else
                    {
                        return 0;
                    }
                }
                if (m == i - n + 2 && z == j + n - 2)//比较到最后一位时
                {
                    if (board[m][z] == board[m -1][z + 1])
                    {
                        return 1;
                    }
                    else
                    {
                        return 0;
                    }
                }
            }
        }
        else
        {
            return 0;
        }
    }
    else
    {
        return 0;
    }
}

//判断从该子往右下数共n个数是否一样
int pan_duan_youxia(char board[ROW][LIN], int i, int j, int n)
{
    //首先判断此位置是是否为空,为空则不需要判断
    if (board[i][j] != ' ')
    {
        //判断从改子往左下是否连成三子
        //先判断往左下数是都由三个格子,没有则不需要判断
        if (ROW - 1 - i >= n - 1 && LIN - 1 - j >= n - 1)
        {
            //三子需要判断三次,n子需要判断n-1次,当前位置与下一个位置进行比较
            int m = i;
            int z = j;//用来控制判断次数
            for (m = i, z = j; m <= i + n - 2, z <= j + n - 2; m++, z++)
            {
                if (m != i + n - 2 && z != j + n - 2)//还未比较到最后一位
                {
                    if (board[m][z] == board[m + 1][z + 1])
                    {
                        continue;
                    }
                    else
                    {
                        return 0;
                    }
                }
                if (m == i + n - 2 && z == j + n - 2)//比较到最后一位时
                {
                    if (board[m][z] == board[m + 1][z + 1])
                    {
                        return 1;
                    }
                    else
                    {
                        return 0;
                    }
                }
            }
        }
        else
        {
            return 0;
        }
    }
    else
    {
        return 0;
    }
}

//判断是否连成三子

int pan_duan(char board[ROW][LIN],int row,int lin)
{
    int n = 3;//3表明判断成三子
    int i = 0;
    int j = 0;
    int shang = 0;
    int xia = 0;
    int zuo = 0;
    int you = 0;
    int zuoshang = 0;
    int youshang = 0;
    int zuoxia = 0;
    int youxia = 0;
    for (i = 0; i < row; i++)
    {
        for (j = 0; j < lin; j++)
        {
            //判断从改子往上数共n个数是否一样
            shang = pan_duan_shang(board, i, j,n);
            if (shang == 1)
            {
                return 1;
            }
            
            //判断从改子往下数共n个数是否一样
            xia  = pan_duan_xia(board, i, j, n);
            if (xia == 1)
            {
                return 1;
            }
            
            //判断从改子往上数共n个数是否一样
            zuo = pan_duan_zuo(board, i, j, n);
            if (zuo == 1)
            {
                return 1;
            }
            
            //判断从改子往上数共n个数是否一样
            you = pan_duan_you(board, i, j, n);
            if (you == 1)
            {
                return 1;
            }
            
            //判断从改子往上数共n个数是否一样
            zuoshang = pan_duan_zuoshang(board, i, j, n);
            if (zuoshang == 1)
            {
                return 1;
            }
            
            //判断从改子往上数共n个数是否一样
            zuoxia = pan_duan_zuoxia(board, i, j, n);
            if (zuoxia == 1)
            {
                return 1;
            }
            
            //判断从改子往上数共n个数是否一样
            youshang = pan_duan_youshang(board, i, j, n);
            if (youshang == 1)
            {
                return 1;
            }
            
            //判断从改子往上数共n个数是否一样
            youxia = pan_duan_youxia(board, i, j, n);
            if (youxia == 1)
            {
                return 1;
            }
            
        }
    }
    return 0;
}

//int pan_duan(char board[ROW][LIN], int i, int j)
//{
//    int n = 3;//3表明判断成三子
//    int i = 0;
//    int j = 0;
//    int shang = 0;
//    int xia = 0;
//    int zuo = 0;
//    int you = 0;
//    int zuoshang = 0;
//    int youshang = 0;
//    int zuoxia = 0;
//    int youxia = 0;
//    for (i = 0; i < row; i++)
//    {
//        for (j = 0; j < lin; j++)
//        {
//            //判断从改子往上数共n个数是否一样
//            shang = pan_duan_shang(board, i, j, n);
//            if (shang == 1)
//            {
//                return 1;
//            }
//
//            //判断从改子往下数共n个数是否一样
//            xia = pan_duan_xia(board, i, j, n);
//            if (xia == 1)
//            {
//                return 1;
//            }
//
//            //判断从改子往上数共n个数是否一样
//            zuo = pan_duan_zuo(board, i, j, n);
//            if (zuo == 1)
//            {
//                return 1;
//            }
//
//            //判断从改子往上数共n个数是否一样
//            you = pan_duan_you(board, i, j, n);
//            if (you == 1)
//            {
//                return 1;
//            }
//
//            //判断从改子往上数共n个数是否一样
//            zuoshang = pan_duan_zuoshang(board, i, j, n);
//            if (zuoshang == 1)
//            {
//                return 1;
//            }
//
//            //判断从改子往上数共n个数是否一样
//            zuoxia = pan_duan_zuoxia(board, i, j, n);
//            if (zuoxia == 1)
//            {
//                return 1;
//            }
//
//            //判断从改子往上数共n个数是否一样
//            youshang = pan_duan_youshang(board, i, j, n);
//            if (youshang == 1)
//            {
//                return 1;
//            }
//
//            //判断从改子往上数共n个数是否一样
//            youxia = pan_duan_youxia(board, i, j, n);
//            if (youxia == 1)
//            {
//                return 1;
//            }
//
//        }
//    }
//    return 0;
//}
//比较两个字符是否相等
int bi_jiao(char a, char b)
{
    if (a == b)
    {
        return 1;
    }
    else
    {
        return 0;
    }
}

//玩家下棋
void player(char board[ROW][LIN])
{
    
    int x = 0;
    int y = 0;
    char signal = 0;
    do
    {
        printf("请输入您要下的位置:\n");
        printf("请输入您要输入的符号\n");
        scanf("%d %d %c", &x, &y, &signal);
        if (board[x - 1][y - 1] != ' ')
        {
            printf("对不起,您输入的位置已经下过了,请重新输入\n");
        }
        if (board[x - 1][y - 1] == ' ')
        {
            board[x - 1][y - 1] = signal;
            break;
        }
    } while (1);
}

//电脑下棋
void computer(char board[ROW][LIN])
{
    int x = 0;
    int y = 0;
    while (1)
    {
        x = rand() % ROW +1;
        y = rand() % LIN +1;

        if (x >= 1 && x <= ROW && y >= 1 && y <= LIN)
        {
            if (board[x-1 ][y-1 ] == ' ')
            {
                board[x-1 ][y-1 ] = '+';
                break;
            }
            else
            {
                continue;
            }
        }
        else
        {
            continue;
        }
    
    }
}

代码实现:test.c

#define _CRT_SECURE_NO_WARNINGS 
//用来测试游戏的逻辑
#include"game.h"

int main()
{
    int input = 0;
    ceshi();
    //首先打印菜单,选择游戏模式
    do
    {
        meau();
        printf("请输入您要选择的游戏模式-->\n");
        scanf("%d", &input);
        switch (input)
        {
        case 1:
            game();//游戏逻辑的实现
            printf("\n=========================================================\n\n");
            break;
        case 0:
            printf("成功退出游戏\n");
            printf("\n=========================================================\n\n");
            break;
        default:
            printf("对不起,您选择的模式错误\n");
            printf("\n=========================================================\n\n");
            break;
        }
    } while (input);
    return 0;
}

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值