zoukankan      html  css  js  c++  java
  • 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; 
    }
    
  • 相关阅读:
    谈谈surging引擎的tcp、http、ws协议和如何容器化部署
    Surging如何使用Swagger 组件测试业务模块
    Ocelot简易教程(七)之配置文件数据库存储插件源码解析
    [转载]Ocelot简易教程(六)之重写配置文件存储方式并优化响应数据
    [转载]Ocelot简易教程(五)之集成IdentityServer认证以及授权
    [转载]Ocelot简易教程(四)之请求聚合以及服务发现
    [转载]Ocelot简易教程(三)之主要特性及路由详解
    [转载]Ocelot简易教程(二)之快速开始2
    [转载]Ocelot简易教程(二)之快速开始1
    Next Permutation
  • 原文地址:https://www.cnblogs.com/ShineEternal/p/10834346.html
Copyright © 2011-2022 走看看