• c++小游戏——五子棋


    #include<iostream> 
    #include<iomanip> 
    #include<cstring> 
    using namespace std; 
    
    const int X = 21; //棋盘行数 
    const int Y = 21; //棋盘列数 
    char p[X][Y]; //定义棋盘 
    int m=0;//定义临时点,保存输入坐标 
    int n=0; 
    
    void display() //输出棋盘 
    { 
    for(int i=0; i<X; i++) 
    cout<<setw(3)<<setfill(' ')<<i; 
    cout<<endl; 
    for(int i=1; i<Y; i++) 
    { 
    cout<<setw(3)<<setfill(' ')<<i; 
    for(int j=1;j<X;j++) 
    cout<<setw(3)<<setfill(' ')<<p[i][j]; 
    cout<<endl; 
    } 
    
    } 
    
    void black() //黑方落子 
    { 
    cout<<"请黑方输入落子位置:
    " 
    <<"请输入落子的行数:"; 
    cin>>m; 
    cout<<"请输入落子的列数:"; 
    cin>>n; 
    if(m<=0||m>=X||n>=Y||n<=0) 
    { 
    cout<<"超出棋盘范围,请重新输入正确坐标!
    "; 
    black(); 
    } 
    else if((p[m][n]==1)||p[m][n]==2) 
    { 
    cout<<"该点已有棋子,请重新选取落子点!
    "; 
    black(); 
    } 
    else 
    p[m][n]=1; //黑方用1来表示 
    
    display(); 
    } 
    
    void red() //红方落子 
    { 
    cout<<"请红方输入落子位置:
    " 
    <<"请输入落子的行数:"; 
    cin>>m; 
    cout<<"请输入落子的列数:"; 
    cin>>n; 
    if(m>=X||m<=0||n<=0||n>=Y) 
    { 
    cout<<"超出棋盘范围,请重新输入正确坐标!
    "; 
    red(); 
    } 
    else if((p[m][n]==1)||p[m][n]==2) 
    { 
    cout<<"该点已有棋子,请重新选取落子点!
    "; 
    red(); 
    } 
    else 
    p[m][n]=2; //红方用2来表示 
    
    display(); 
    } 
    
    int evalue() //只需要判断落子点为中心的九点“米”字是否连续即可 
    { 
    int k = 0,r = 0; 
    /*斜线判断*/ 
    for(k=3;k<X-2;k++) //两条,其中的p[k][r]!='-'是排除空子的情况 
    { 
    for(r=3;r<Y-2;r++) 
    { 
    if(p[k][r]!='-'&&p[k-2][r-2]==p[k][r]&&p[k-1][r-1]==p[k][r]&&p[k+1][r+1]==p[k][r]&&p[k+2][r+2]==p[k][r]) 
    return 1; 
    else if(p[k][r]!='-'&&p[k+2][r-2]==p[k][r]&&p[k+1][r-1]==p[k][r]&&p[k-1][r+1]==p[k][r]&&p[k-2][r+2]==p[k][r]) 
    return 1; 
    } 
    } 
    /*横线判断*/ 
    for(k=1;k<X;k++) //p[k][r]!='-'是排除空子的情况 
    for(r=3;r<Y-2;r++) 
    if(p[k][r]!='-'&&p[k][r-2]==p[k][r]&&p[k][r-1]==p[k][r]&&p[k][r+1]==p[k][r]&&p[k][r+2]==p[k][r]) 
    return 1; 
    /*竖线判断*/ 
    for(k=3;k<X-2;k++) //p[k][r]!='-'是排除空子的情况 
    for(r=1;r<Y;r++) 
    if(p[k][r]!='-'&&p[k-2][r]==p[k][r]&&p[k-1][r]==p[k][r]&&p[k+1][r]==p[k][r]&&p[k+2][r]==p[k][r]) 
    return 1; 
    return 0; 
    } 
    
    int main() 
    { 
    memset(p,'-',441); //初始化为‘-’ 
    cout<<"欢迎使用简易双人对战五子棋游戏
    " 
    <<"五子棋棋谱如下:
    "; 
    display(); 
    while(1) 
    { 
    red(); 
    if(evalue()) 
    { 
    cout<<"红方赢!
    "; 
    break; 
    } 
    black(); 
    if(evalue()) 
    { 
    cout<<"黑方赢!
    "; 
    break; 
    } 
    } 
    return 0; 
    }
    
  • 相关阅读:
    谷粒商城分布式基础(二)—— 环境搭建(基础篇)(虚拟机 & JDK & Maven & docker & mysql & redis & vue)
    RocketMQ笔记
    SpringCloud(Alibaba)笔记
    面试题
    Redis6笔记
    谷粒商城分布式基础(一)—— 项目简介 & 分布式基础
    rabbitmq 笔记
    谷粒商城分布式基础(三)—— 开发配置统一 & 服务构建
    MySQL高级笔记
    Nginx笔记
  • 原文地址:https://www.cnblogs.com/ShineEternal/p/10834346.html
Copyright © 2020-2023  润新知