• C语言之二维数组棋盘游戏


    #include<iostream>
    
    #include<stdio.h>
    using namespace std;
    int main()
    {
    //-1 没人赢 0:O赢 1:X赢
    int size;
    printf("0表示“甲方”,1表示“乙方”
    
    ");
    printf("请输入矩阵的大小
    ");
    while (scanf("%d", &size) == 1)
    {
    int board[100][100];
    int num_of_O;
    int num_of_X;
    int result = -1;
    int i, j;
    for (i = 0; i < size; i++)
    for (j = 0; j < size; j++)
    {
    scanf("%d", &board[i][j]);
    }
    
    //检查行
    for (i = 0; i < size&&result == -1; i++)
    {
    num_of_O = num_of_X = 0;
    for (j = 0; j < size; j++)
    {
    if (board[i][j] == 1)
    {
    num_of_X++;
    }
    else if(board[i][j] == 0)
    {
    num_of_O++;
    }
    }
    if (num_of_O == size)
    {
    result = 0;
    }
    else
    if (num_of_X == size)
    {
    result = 1;
    }
    }
    
    //检查列
    if (result == -1)
    {
    for (j = 0; j < size&&result == -1; j++)
    {
    num_of_O = num_of_X = 0;
    for (i = 0; i < size; i++)
    {
    if (board[i][j] == 1)
    {
    num_of_X++;
    }
    else
    if (board[i][j] == 0)
    {
    num_of_O++;
    }
    }
    if (num_of_O == size)
    {
    result = 0;
    }
    else
    if (num_of_X == size)
    {
    result = 1;
    }
    }
    }
    //检查正对角线
    num_of_O = num_of_X = 0;
    for (i = 0; i < size; i++)
    {
    if (board[i][i] == 1)
    {
    num_of_X++;
    }
    else
    if (board[i][i] ==0 )
    {
    num_of_O++;
    }
    
    }
    
    if (num_of_O == size)
    {
    result = 0;
    }
    else
    if (num_of_X == size)
    {
    result = 1;
    }
    
    //检查反对角线
    num_of_O = num_of_X = 0;
    for (i = 0; i < size; i++)
    {
    if (board[i][size - 1 - i] == 1)//反对角线计算方法
    {
    num_of_X++;
    }
    else
    if (board[i][size - 1 - i] == 0)
    {
    num_of_O++;
    }
    }
    
    if (num_of_O == size)
    {
    result = 0;
    }
    else
    if (num_of_X == size)
    {
    result = 1;
    }
    
    if (result == -1)
    {
    printf("抱歉啊,没有人赢哦!
    不服,再战!
    ");
    }
    else
    if (result == 0)
    {
    printf("恭喜!!!甲方赢啦
    ");
    }
    else
    if (result == 1)
    {
    printf("恭喜!!!乙方赢啦
    ");
    }
    printf("请输入矩阵的大小
    ");
    }
    return 0;
    }
    以大多数人努力程度之低,根本轮不到去拼天赋~
  • 相关阅读:
    判断是否是移动端
    html上传文件类型限制accept的全部属性值
    前端cropper裁剪图像大小(原创)
    eslint加不加分号
    手机浏览器使用rem 自适应html宽度大小
    DOMContentLoaded与load的区别
    ES6语法find查找匹配数组
    React的JSX语法
    React的基本使用
    React简介
  • 原文地址:https://www.cnblogs.com/gcter/p/5746743.html
Copyright © 2020-2023  润新知