C语言五子棋小游戏实现代码

 更新时间:2022年08月05日 15:27:35   作者:我今年十六岁  
这篇文章主要为大家详细介绍了C语言五子棋小游戏实现代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现五子棋小游戏的具体代码,供大家参考,具体内容如下

#include<stdio.h>
#include<windows.h>
#define ROW 14
#define COL 14
 
void gotoxy(int x,int y)//形参
{
    HANDLE hOut;
    COORD pos= {x,y};
    // 光标的起始位(第1列,第3行) 0是第1列 2是第3行
    hOut = GetStdHandle(STD_OUTPUT_HANDLE);
    SetConsoleCursorPosition(hOut, pos);
    //printf("定位光标位置搜索(%d,%d)\n",pos.X,pos.Y);
}
 
/*
函数名:paintGameUI()
函数功能:绘制棋盘
函数参数:无
函数返回值:无
*/
void paintGameUI()  //打印游戏棋盘  使用ROW COL在上面宏定义可以改变//棋盘大小
{
    int i=0;
    int j=0;
    printf("┌ ");     //顶部
    for(i=0;i<COL;i++)
    {
        printf("┬ ");
    }
    printf("┐\n");
    //中间
    for(j=0;j<ROW;j++)
    {
        printf("├ ");
        for(i=0;i<COL;i++)
        {
            printf("┼ ");    
        }
        printf("┤\n");
    }
    //底部
    printf("└ ");
    for(i=0;i<COL;i++)
    {
        printf("┴ ");
    }
    printf("┘\n");
}
 
void playgame()
{
    int arr[ROW][COL]={0}; // 初始化 0-没有棋子 1用户下棋黑 2电脑下棋白
    int x,y;      //用户输入的行 列
    int row,col;  //落子的位置
    int i,j; //  规则   判断输赢 遍历二维数组
    paintGameUI();     //    绘制棋盘
    while(1)//确保多次 确保用户电脑有效落子多次
    {
        while(1)    //      保证用户能够有效落子一次 用户下棋
        {
            gotoxy(0,16);//打印文字 0距离左边 16距离顶部
            printf("                        ");  //覆盖掉用户之前所输,//让用户可以再输
            gotoxy(0,16); //打印文字 0距离左边 16距离顶部
            
            printf("请输入下棋的位置,例如:(2 3):");
            scanf("%d %d",&x,&y);
            row = x-1;  //行 距离顶部的长度 数组是0开始的
            col =y-1;  //列 距离左边的长度 下棋的位置
            if(arr[row][col]==0)   //下棋位置是否是棋子
            {   
                gotoxy(col*2,row); 
                printf("●");//用户下棋
                //修改二维数组的值
                arr[row][col]=1; //用户下棋
                for(i=0;i<ROW;i++)    
                {    
                    for(j=0;j<COL;j++)   
                    {
                        //横着五个都是1  列变
                        if( arr[i][j]==arr[i][j+1]&&arr[i][j]==arr[i][j+2]&& 
                            arr[i][j]==arr[i][j+3]&&arr[i][j]==arr[i][j+4]&&j+4<=COL&&arr [i][j]==1)
                        {
                            gotoxy(0,18);
                            printf("用户赢了\n");
                            return ;    
                            
                        }//竖着五个都是1 行变
                        else if(arr[i][j]==arr[i+1][j]&&arr[i][j]==arr[i+2][j]&& 
                            arr[i][j]==arr[i+3][j]&&arr[i][j]==arr[i+4][j]&&i+4<=ROW&&arr [i][j]==1)
                        {
                            gotoxy(0,18);
                            printf("用户赢了\n");
                            return ;   
                        }    
                    }
                }
                break;    //轮到对方下棋    
            }
            else if(arr[row][col]==1||arr[row][col]==2)  //用户下棋1 电脑下棋2
            {
                gotoxy(0,17);
                printf("请重新输入坐标");
            }    
        }
        while(1) //    确保电脑有效落子一次 电脑下棋
        {
            //电脑下棋  电脑随机落子
            row= rand()%14+0;  //二维数组索引0-13  
            col= rand()%14+0;  //电脑随机落子
            //行距离顶部row  列距离左边col
            if(arr[row][col]==0)   //下棋位置是否是棋子 空 电脑可以下棋
            {   
                gotoxy(col*2,row);
                printf("○");//下棋
                //修改二维数组的值
                arr[row][col]=2; //电脑下棋
                for(i=0;i<ROW;i++)     //电脑赢 最好用算法
                {
                    for(j=0;j<COL;j++)
                    {
                        //横着五个都是1  列变
                        if( arr[i][j]==arr[i][j+1]&&arr[i][j]==arr[i][j+2]&& 
                            arr[i][j]==arr[i][j+3]&&arr[i][j]==arr[i][j+4]&&j+4<=COL&&arr [i][j]==2)
                        {
                            gotoxy(0,18);
                            printf("电脑赢了\n");
                            return;
                            
                        }//竖着五个都是1
                        else if(arr[i][j]==arr[i+1][j]&&arr[i][j]==arr[i+2][j]&& 
                            arr[i][j]==arr[i+3][j]&&arr[i][j]==arr[i+4][j]&&i+4<=ROW&&arr [i][j]==2)
                        {
                            gotoxy(0,18);
                            printf("电脑赢了\n");
                            return; 
                        }    
                    }
                }
                break;    
            }    
        }    
    }
}
 
int main()
{
    playgame();    
    return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言中的数据类型详解

    C语言中的数据类型详解

    在C语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式,本文将详细给大家介绍一下C语言中的基本数据类型,感兴趣的同学可以参考下
    2023-05-05
  • 讲解C语言编程中指针赋值的入门实例

    讲解C语言编程中指针赋值的入门实例

    这篇文章主要介绍了讲解C语言编程中指针赋值的入门实例,通过const int i与int *const pi这样两个例子来分析指针的赋值和地址指向,需要的朋友可以参考下
    2015-12-12
  • C语言不使用strcpy函数如何实现字符串复制功能

    C语言不使用strcpy函数如何实现字符串复制功能

    这篇文章主要给大家介绍了关于C语言不使用strcpy函数如何实现字符串复制功能的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • C++ operator关键字(重载操作符)的用法详解

    C++ operator关键字(重载操作符)的用法详解

    下面小编就为大家带来一篇C++ operator关键字(重载操作符)的用法详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • C语言与C++中内存管理详解

    C语言与C++中内存管理详解

    本章主要介绍C语言与C++的内存管理,以C++的内存分布作为引入,介绍C++不同于C语言的内存管理方式(new delete对比 malloc free),感兴趣的朋友来看看吧
    2022-04-04
  • C++实现LeetCode(72.编辑距离)

    C++实现LeetCode(72.编辑距离)

    这篇文章主要介绍了C++实现LeetCode(72.编辑距离),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • 详解C++中的菱形继承问题

    详解C++中的菱形继承问题

    这篇文章主要介绍了详解C++中的菱形继承问题,在多继承结构中,存在着很多问题,比如从不同基类中继承了同名成员,派生类中也定义了同名成员,这种二义性问题很好解决,加上要访问的基类的类名限制就可以了,需要的朋友可以参考下
    2023-08-08
  • C语言实现桶排序的方法示例

    C语言实现桶排序的方法示例

    这篇文章主要介绍了C语言实现桶排序的方法,简单描述了桶排序的概念、原理并结合实例形式分析了C语言实现桶排序算法的具体操作技巧,需要的朋友可以参考下
    2018-01-01
  • C++指针运算符(&和*)的实现

    C++指针运算符(&和*)的实现

    C++ 提供了两种指针运算符,一种是取地址运算符 &,一种是间接寻址运算符 *,本文就详细的介绍一下这两种运算符的使用,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • C++中strtok()函数的用法介绍

    C++中strtok()函数的用法介绍

    以下是对C++中strtok()函数的使用方法进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-09-09

最新评论