欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言實(shí)現(xiàn)簡易三子棋

 更新時(shí)間:2021年07月29日 09:24:29   作者:往明  
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡易三子棋,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

前言

檢驗(yàn)學(xué)習(xí)成果最好的方式是實(shí)踐,在學(xué)習(xí)完C語言的函數(shù)和數(shù)組以后,就可以簡易的實(shí)現(xiàn)一些小游戲,本文將介紹如何實(shí)現(xiàn)三字棋小游戲。歡迎探討

思路分析

三子棋的規(guī)則是在3X3的棋盤里,率先將自己的三個(gè)棋子連成一條直線為贏家,程序?qū)崿F(xiàn)的核心是玩家的落子以及輸贏的判斷。
核心流圖:當(dāng)前棋盤->玩家1移動(dòng)->當(dāng)前棋盤->輸贏判斷->玩家2移動(dòng)->當(dāng)前棋盤->判斷輸贏->玩家1移動(dòng)······

函數(shù)實(shí)現(xiàn)

玩家落子

玩家輸入坐標(biāo)將棋子落入棋盤中,即為向一個(gè)二維數(shù)組賦值。需要注意的時(shí),輸入的坐標(biāo)不能超出數(shù)組范圍,并且不能占用被輸入的位置。

void PlayerMove(char board[ROW][COL], int row, int col)
{
 printf("玩家走:>\n");

 int x = 0;
 int y = 0;
 while (1)
 {
  printf("請輸入坐標(biāo):>");
  scanf("%d%d", &x, &y);
  if (x >= 1 && x <= row && y >= 1 && y <= col)
  {
   if (board[x - 1][y - 1] == ' ')
   {
    board[x - 1][y - 1] = '*';
    break;
   }
   else
   {
    printf("坐標(biāo)被占用,請重新輸入\n");
   }
  }
  else
  {
   printf("坐標(biāo)非法,超出范圍\n");
  }
 }
}

當(dāng)前棋盤

實(shí)質(zhì)是輸出二維數(shù)組
輸出二維數(shù)組,但是為了美化棋盤,我們需要一些符號(hào)來分割棋盤,讓它結(jié)構(gòu)清晰。

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");
 }
}

判斷輸贏

只要我們找到三個(gè)連成一條直線的棋子即可,這里選三個(gè)棋子中中間那個(gè)即可。然后判斷是不是滿足條件。
說明:
返回*,表示輸入*的玩家贏;
返回#,表示輸入#的玩家贏;
返回 Q,表示平局;
返回C,表示游戲繼續(xù)。

char IsWin(char board[ROW][COL], int row, int col){
 int i, j, count = 0;
 for(i=0;i<row;i++)
  for (j = 0; j < col; j++) {
   if (board[i][j] == '*') {
    if (i-1>=0&&i+1<row&&board[i-1][j] == '*' && board[i + 1][j] == '*')
     return '*';
    if (j-1>=0&&j+1<col&&board[i][j-1] == '*' && board[i][j + 1] == '*')
     return '*';
    if (i-1 >=0 && i + 1 < row && j - 1 >= 0 && j + 1 < col&& board[i-1][j-1] == '*' && board[i + 1][j + 1] == '*')
     return '*';
    if (i-1 >= 0 && i + 1 < row && j - 1 >= 0 && j + 1 < col && board[i - 1][j + 1] == '*' && board[i + 1][j - 1] == '*')
     return '*';
   }
   if (board[i][j] == '#') {
    if (i - 1 >= 0 && i + 1 < row && board[i - 1][j] == '#' && board[i + 1][j] == '#')
     return '#';
    if (j - 1 >= 0 && j + 1 < col && board[i][j - 1] == '#' && board[i][j + 1] == '#')
     return '#';
    if (i-1 >= 0 && i + 1 < row && j - 1 >= 0 && j + 1 < col && board[i - 1][j - 1] == '#' && board[i + 1][j + 1] == '#')
     return '*';
    if (i-1 >= 0 && i + 1 < row && j - 1 >= 0 && j + 1 < col && board[i - 1][j + 1] == '#' && board[i + 1][j - 1] == '#')
     return '#';
   }
   if (board[i][j] == ' ')
    count++;
  }
 if (count == 0)
  return 'Q';
 else
  return 'C';
}

源碼實(shí)現(xiàn)

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.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 Player1Move(char board[ROW][COL], int row, int col);
void Player2Move(char board[ROW][COL], int row, int col);
char IsWin(char board[ROW][COL], int row, int col);
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] = ' ';
  }
 }
}//棋盤初始化,二維數(shù)組全部初始化空格
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");
 }
}//棋盤打印函數(shù),打印出當(dāng)前棋盤
void Player1Move(char board[ROW][COL], int row, int col)
{
 printf("玩家1走:>\n");

 int x = 0;
 int y = 0;
 while (1)
 {
  printf("請輸入坐標(biāo):>");
  scanf("%d%d", &x, &y);//2 1 -- > 1 0
  if (x >= 1 && x <= row && y >= 1 && y <= col)
  {
   if (board[x - 1][y - 1] == ' ')
   {
    board[x - 1][y - 1] = '*';
    break;
   }
   else
   {
    printf("坐標(biāo)被占用,請重新輸入\n");
   }
  }
  else
  {
   printf("坐標(biāo)非法,超出范圍\n");
  }
 }
}
void Player2Move(char board[ROW][COL], int row, int col)
{
 printf("玩家1走:>\n");

 int x = 0;
 int y = 0;
 while (1)
 {
  printf("請輸入坐標(biāo):>");
  scanf("%d%d", &x, &y);//2 1 -- > 1 0
  if (x >= 1 && x <= row && y >= 1 && y <= col)
  {
   if (board[x - 1][y - 1] == ' ')
   {
    board[x - 1][y - 1] = '#';
    break;
   }
   else
   {
    printf("坐標(biāo)被占用,請重新輸入\n");
   }
  }
  else
  {
   printf("坐標(biāo)非法,超出范圍\n");
  }
 }
}
char IsWin(char board[ROW][COL], int row, int col) {
 int i, j, count = 0;
 for (i = 0; i < row; i++)
  for (j = 0; j < col; j++) {
   if (board[i][j] == '*') {
    if (i - 1 >= 0 && i + 1 < row && board[i - 1][j] == '*' && board[i + 1][j] == '*')
     return '*';
    if (j - 1 >= 0 && j + 1 < col && board[i][j - 1] == '*' && board[i][j + 1] == '*')
     return '*';
    if (i - 1 >= 0 && i + 1 < row && j - 1 >= 0 && j + 1 < col && board[i - 1][j - 1] == '*' && board[i + 1][j + 1] == '*')
     return '*';
    if (i - 1 >= 0 && i + 1 < row && j - 1 >= 0 && j + 1 < col && board[i - 1][j + 1] == '*' && board[i + 1][j - 1] == '*')
     return '*';
   }
   if (board[i][j] == '#') {
    if (i - 1 >= 0 && i + 1 < row && board[i - 1][j] == '#' && board[i + 1][j] == '#')
     return '#';
    if (j - 1 >= 0 && j + 1 < col && board[i][j - 1] == '#' && board[i][j + 1] == '#')
     return '#';
    if (i - 1 >= 0 && i + 1 < row && j - 1 >= 0 && j + 1 < col && board[i - 1][j - 1] == '#' && board[i + 1][j + 1] == '#')
     return '*';
    if (i - 1 >= 0 && i + 1 < row && j - 1 >= 0 && j + 1 < col && board[i - 1][j + 1] == '#' && board[i + 1][j - 1] == '#')
     return '#';
   }
   if (board[i][j] == ' ')
    count++;
  }
 if (count == 0)
  return 'Q';
 else
  return 'C';
}

int main()
{
 char board[ROW][COL];
 InitBoard(board, ROW, COL);
 DisplayBoard(board, ROW, COL);
 char ret = 0;
 while (1)
 {
  Player1Move(board, ROW, COL);
  DisplayBoard(board, ROW, COL);
  ret = IsWin(board, ROW, COL);
  if (ret != 'C')
  {
   break;
  }
  Player2Move(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");
 }
 return 0;
}

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

相關(guān)文章

  • C++逆向分析移除鏈表元素實(shí)現(xiàn)方法詳解

    C++逆向分析移除鏈表元素實(shí)現(xiàn)方法詳解

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(203.移除鏈表元素),本篇文章通過逆向分析的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2022-11-11
  • C++實(shí)現(xiàn)LeetCode(82.移除有序鏈表中的重復(fù)項(xiàng)之二)

    C++實(shí)現(xiàn)LeetCode(82.移除有序鏈表中的重復(fù)項(xiàng)之二)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(82.移除有序鏈表中的重復(fù)項(xiàng)之二),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • c++中vector的使用和模擬實(shí)現(xiàn)

    c++中vector的使用和模擬實(shí)現(xiàn)

    這篇文章主要介紹了c++中vector的使用和模擬實(shí)現(xiàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • C語言模式實(shí)現(xiàn)C++繼承和多態(tài)的實(shí)例代碼

    C語言模式實(shí)現(xiàn)C++繼承和多態(tài)的實(shí)例代碼

    本篇文章主要介紹了C語言模式實(shí)現(xiàn)C++繼承和多態(tài)的實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • C語言實(shí)現(xiàn)五子棋對戰(zhàn)系統(tǒng)

    C語言實(shí)現(xiàn)五子棋對戰(zhàn)系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)五子棋對戰(zhàn)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C語言之飛機(jī)大戰(zhàn)游戲

    C語言之飛機(jī)大戰(zhàn)游戲

    這篇文章主要為大家詳細(xì)介紹了C語言之飛機(jī)大戰(zhàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • 深入探索C++ string的底層實(shí)現(xiàn)

    深入探索C++ string的底層實(shí)現(xiàn)

    C語言中的字符串是以字符數(shù)組的形式存儲(chǔ)的,每個(gè)字符占用一個(gè)字節(jié)的內(nèi)存空間,本文我們將和大家一起深入探討一下string的底層實(shí)現(xiàn),感興趣的小伙伴快來和小編一起吧
    2023-08-08
  • 基于Qt實(shí)現(xiàn)視頻播放器功能

    基于Qt實(shí)現(xiàn)視頻播放器功能

    本文通過實(shí)例代碼給大家介紹了基于Qt實(shí)現(xiàn)視頻播放器功能,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-09-09
  • 減小VC6編譯生成的exe文件的大小的方法

    減小VC6編譯生成的exe文件的大小的方法

    這篇文章主要介紹了減小VC6編譯生成的exe文件的大小的方法,需要的朋友可以參考下
    2015-01-01
  • QT應(yīng)用程序cout輸出中文亂碼解決方法

    QT應(yīng)用程序cout輸出中文亂碼解決方法

    本文主要介紹了QT應(yīng)用程序cout輸出中文亂碼解決方法,文中通過圖文的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01

最新評論