亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

用C語言實現(xiàn)簡單五子棋小游戲

 更新時間:2021年07月30日 11:24:27   作者:Stout800  
這篇文章主要為大家詳細介紹了用C語言實現(xiàn)簡單五子棋小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現(xiàn)簡單五子棋小游戲的具體代碼,供大家參考,具體內(nèi)容如下

在vs2019創(chuàng)建新項目,然后添加兩個源文件test.c和game.c,接著創(chuàng)建一個頭文件game.h。

test.c:

#include "game.h"
 
void game()
{
 char board[ROW][COL];
 InitBoard(board, ROW, COL);
 DisplayBoard(board, ROW, COL);
 char ret = 0;
 while (1)
 {
  PlayerMove(board, ROW, COL);
  DisplayBoard(board, ROW, COL);
  ret = IsWin(board, ROW, COL);
  if (ret != 'C')
  {
   break;
  }
  ComputerMove(board, ROW, COL);
  DisplayBoard(board, ROW, COL);
  ret = IsWin(board, ROW, COL);
  if (ret != 'C')
  {
   break;
  }
 }
 if (ret == '*')
 {
  printf("玩家贏\n");
 }
 else if (ret == '#')
 {
  printf("電腦贏\n");
 }
 else
 {
  printf("平局\n");
 }
}
 
void menu()
{
 printf("******************************\n");
 printf("*******     1.play      ******\n");
 printf("*******     0.exit      ******\n");
 printf("******************************\n");
}
int main()
{
 int input = 0;
 srand((unsigned int)time(NULL));
 do
 {
  menu();
  printf("請輸入:\n");
  scanf("%d", &input);
  switch (input)
  {
  case 1:
   game();
   break;
  case 0:
   printf("退出游戲\n");
   break;
  default:
   printf("輸入錯誤,請重新輸入:\n");
   break;
  }
 } while (input);
 return 0;
}

game.c:

#include "game.h"
 
 
void InitBoard(char board[ROW][COL], int row, int col)
{
 int i = 0;
 for (i = 0; i < row; i++)
 {
  int j = 0;
  for (j = 0; j < col; j++)
  {
   board[i][j] = ' ';
  }
 }
}
 
void DisplayBoard(char board[ROW][COL], int row, int col)
{
 int i = 0;
 for (i = 0; i < row; i++)
 {
  int j = 0;
  for (j = 0; j < col; j++)
  {
   printf(" %c ",board[i][j]);
   if (j < col - 1)
   {
    printf("|");
   }
  }
  printf("\n");
  if (i < row - 1)
  {
   for (j = 0; j < col; j++)
   {
    printf("---");
    if (j < col - 1)
     printf("|");
   }
  }
  printf("\n");
 }
}
 
void PlayerMove(char board[ROW][COL], int row, int col)
{
 printf("玩家走:\n");
 int i = 0;
 int j = 0;
 while (1)
 {
  printf("請輸入坐標:\n");
  scanf("%d%d", &i, &j);
  if (i >= 1 && i <= row && j >= 1 && j <= col)
  {
   if (board[i - 1][j - 1] == ' ')
   {
    board[i - 1][j - 1] = '*';
    break;
   }
   else
   {
    printf("坐標被占用,請重新輸入\n");
   }
  }
  else
  {
   printf("坐標超出范圍\n");
  }
 }
}
 
 
void ComputerMove(char board[ROW][COL], int row, int col)
{
 int i = 0;
 int j = 0;
 printf("電腦走:\n");
 while (1)
 {
  i = rand() % row;
  j = rand() % col;
  if (board[i][j] == ' ')
  {
   board[i][j] = '#';
   break;
  }
 }
}
int IsFull(char board[ROW][COL], int row, int col)
{
 int i = 0;
 int j = 0;
 for (i = 0; i < row; i++)
 {
  for (j = 0; j < col; j++)
  {
   if (board[i][j] == ' ')
   {
    return 0;//棋盤沒滿
   }
  }
 }
 
 return 1;//棋盤滿了
 
}
 
char IsWin(char board[ROW][COL], int row, int col)
{
 int i = 0;
 //判斷三行
 for (i = 0; i < row; i++)
 {
  if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][1] != ' ')
  {
   return  board[i][1];//
  }
 }
 
 //判斷三列
 for (i = 0; i < col; i++)
 {
  if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[1][i] != ' ')
  {
   return board[1][i];
  }
 }
 
 //判斷對角線
 if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[1][1] != ' ')
 {
  return board[1][1];
 }
 if (board[0][2] == board[1][1] && board[1][1] == board[2][0] && board[1][1] != ' ')
 {
  return board[1][1];
 }
 
 //判斷平局
 //如果棋盤滿了返回1, 不滿返回0
 int ret = IsFull(board, row, col);
 if (ret == 1)
 {
  return 'Q';
 }
 
 //繼續(xù)
 return 'C';
}

game.h:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
#define ROW 3
#define COL 3
 
void InitBoard(char board[ROW][COL], int row, int col);
void DisplayBoard(char board[ROW][COL], int row, int col);
void PlayerMove(char board[ROW][COL], int row, int col);
void ComputerMove(char board[ROW][COL], int row, int col);
char IsWin(char board[ROW][COL], int row, int col);
int IsFull(char board[ROW][COL], int row, int col);

運行效果如圖:

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++實現(xiàn)特殊矩陣的壓縮存儲算法

    C++實現(xiàn)特殊矩陣的壓縮存儲算法

    在實際存儲時,會發(fā)現(xiàn)矩陣中有許多值相同的數(shù)據(jù)或有許多零數(shù)據(jù),且分布呈現(xiàn)出一定的規(guī)律,稱這類型的矩陣為特殊矩陣。本文將利用C++實現(xiàn)特殊矩陣的壓縮存儲,感興趣的可以了解一下
    2022-08-08
  • 詳解c++ libuv工作隊列

    詳解c++ libuv工作隊列

    這篇文章主要介紹了c++ libuv工作隊列的相關(guān)資料,幫助大家更好的理解和使用libuv,感興趣的朋友可以了解下
    2021-02-02
  • C語言?隊列的實現(xiàn)全解析

    C語言?隊列的實現(xiàn)全解析

    隊列(Queue)與棧一樣,是一種線性存儲結(jié)構(gòu),它具有如下特點:隊列中的數(shù)據(jù)元素遵循“先進先出”(First?In?First?Out)的原則,簡稱FIFO結(jié)構(gòu)。在隊尾添加元素,在隊頭刪除元素
    2022-04-04
  • C++利用PCL點云庫操作txt文件詳解

    C++利用PCL點云庫操作txt文件詳解

    這篇文章主要為大家詳細介紹了C++如何利用PCL點云庫操作txt文件,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以了解一下
    2024-01-01
  • C語言?超詳細順序表的模擬實現(xiàn)實例建議收藏

    C語言?超詳細順序表的模擬實現(xiàn)實例建議收藏

    程序中經(jīng)常需要將一組數(shù)據(jù)元素作為整體管理和使用,需要創(chuàng)建這種元素組,用變量記錄它們,傳進傳出函數(shù)等。一組數(shù)據(jù)中包含的元素個數(shù)可能發(fā)生變化,順序表則是將元素順序地存放在一塊連續(xù)的存儲區(qū)里,元素間的順序關(guān)系由它們的存儲順序自然表示
    2022-03-03
  • C++數(shù)據(jù)結(jié)構(gòu)之list詳解

    C++數(shù)據(jù)結(jié)構(gòu)之list詳解

    list是一種序列式容器。list容器完成的功能實際上和數(shù)據(jù)結(jié)構(gòu)中的雙向鏈表是極其相似的,list中的數(shù)據(jù)元素是通過鏈表指針串連成邏輯意義上的線性表,也就是list也具有鏈表的主要優(yōu)點,即:在鏈表的任一位置進行元素的插入、刪除操作都是快速的
    2021-11-11
  • C/C++如何實現(xiàn)循環(huán)左移,循環(huán)右移

    C/C++如何實現(xiàn)循環(huán)左移,循環(huán)右移

    這篇文章主要介紹了C/C++如何實現(xiàn)循環(huán)左移,循環(huán)右移,具有很好的參考價值,希望對大家有所幫助。具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • qt中 painter 的用法及原理示例詳解

    qt中 painter 的用法及原理示例詳解

    QPainter是Qt的一個繪圖類,它的主要任務(wù)是在繪圖設(shè)備上進行2D圖形渲染,這篇文章主要介紹了qt中 painter 的用法以及原理,需要的朋友可以參考下
    2023-07-07
  • C++ 字符串string和整數(shù)int的互相轉(zhuǎn)化操作

    C++ 字符串string和整數(shù)int的互相轉(zhuǎn)化操作

    這篇文章主要介紹了C++ 字符串string和整數(shù)int的互相轉(zhuǎn)化操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • 大家注意vector, list, set, map成員函數(shù)erase

    大家注意vector, list, set, map成員函數(shù)erase

    set和map是由紅黑樹來實現(xiàn)的,當erase的時候迭代器就失效了,也就是說我們要在迭代器失效之前保留一個副本,根據(jù)這個副本我們才能繼續(xù)遍歷下一個元素
    2013-09-09

最新評論