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

C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單三子棋程序

 更新時(shí)間:2020年04月08日 10:10:47   作者:木頭i  
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單三子棋程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

使用C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單的三子棋程序,主要是對(duì)二維數(shù)組的運(yùn)用,我們需要一個(gè)頭文件,兩個(gè)源文件來(lái)實(shí)現(xiàn)。

game.h //包含函數(shù)的聲明,宏定義
test.c //包含主函數(shù),函數(shù)調(diào)用
game.c //包含函數(shù)的定義

整體思路

1.要完成一個(gè)簡(jiǎn)單的三子棋程序,首先需要?jiǎng)?chuàng)建一個(gè)二維數(shù)組,并完成數(shù)組初始化。

//使用宏定義定義常量,方便之后對(duì)數(shù)組的使用
#define ROW 3 //行
#define COL 3 //列

char arr[ROW][COL] = { 0 };
Arr_init(arr, ROW, COL); //數(shù)組初始化

2.完成數(shù)組的初始化后,我們需要將三子棋所需要的棋盤(pán)打印出來(lái)。

void Print_che(char arr[ROW][COL], int row, int col) //打印棋盤(pán)
{
 int i, j;
 for(i = 0; i < row; i++)
 {
 for(j = 0; j < col; j++)
 {
 printf(" %c ", arr[i][j]);
 if (j < col - 1)
 printf("|");
 }
 printf("\n");
 for(j = 0; j < col ; j++)
 {
 if (i < row - 1)
 printf("___");
 else
 printf(" ");
 if (j < col - 1)
 printf("|");
 }
 printf("\n");
 }
}

3.打印完棋盤(pán)后,我們就要開(kāi)始下棋了,為了增加游戲的難度,我們讓電腦先走,電腦走的字符為'0'。

void Computer_walk(char arr[ROW][COL], int row, int col) //電腦走
{
 int x, y;
 printf("請(qǐng)電腦輸入坐標(biāo)\n");
 while(1)
 {
 x = rand() % row; //生成隨機(jī)數(shù)
 y = rand() % col;
 if (arr[x][y] == ' ') //判斷坐標(biāo)正確性
 {
 arr[x][y] = '0';
 break;
 }
 }
}

4.電腦走完后,輪到玩家走,玩家走的字符為'X'。

void Player_go(char arr[ROW][COL], int row, int col) //玩家走
{
 int x, y;
 printf("請(qǐng)玩家輸入坐標(biāo):");
 while (1)
 {
 scanf("%d %d", &x, &y);
 if ((x > 0 && x <= row + 1) && (y > 0 && y <= col + 1)) //判斷坐標(biāo)正確性
 {
 if (arr[x - 1][y - 1] == ' ')
 {
 arr[x - 1][y - 1] = 'X';
 break;
 }
 else
 printf("輸入錯(cuò)誤,請(qǐng)重新輸入:");
 }
 else
 printf("輸入錯(cuò)誤,請(qǐng)重新輸入:");
 }
}

5.電腦和玩家每走一次,都需要判斷一次輸贏。

char Judge_win(char arr[ROW][COL], int row, int col) //判斷輸贏
{
 int i, j;
 int count = 0;
 for (i = 0; i < row; i++)
 {
 if (arr[i][0] == arr[i][1] && arr[i][1] == arr[i][2] && arr[i][0] != ' ') //行相等
 return arr[i][1];
 if (arr[0][i] == arr[1][i] && arr[1][i] == arr[2][i] && arr[0][i] != ' ') //列相等
 return arr[1][i];
 if (arr[0][0] == arr[1][1] && arr[1][1] == arr[2][2] && arr[1][1] != ' ') //正斜相等
 return arr[1][1];
 if (arr[0][2] == arr[1][1] && arr[1][1] == arr[2][0] && arr[1][1] != ' ') //反斜相等
 return arr[1][1];
 }
 for (i = 0; i < row; i++)//平局
 {
 for (j = 0; j < col; j++)
 {
 if (arr[i][j] == 'X' || arr[i][j] == '0') //遍歷數(shù)組,查看是否還有沒(méi)有走的地方
 {
 count++;
 if (count == 9)
 return 'Q';
 }
 }
 }
 return 'A';
}

確定大致思路后,我們完成程序的流程部分,放入我們所創(chuàng)建的文件中。

代碼如下:

game.h //包含函數(shù)的聲明,宏定義

#ifndef _GAME_H__
#define _GAME_H__

#include <stdio.h>
#include <windows.h>
#include <stdlib.h>
#include <time.h>

#define ROW 3 //行
#define COL 3 //列

void Arr_init(char arr[ROW][COL], int row, int col); //數(shù)組初始化
void Print_che(char arr[ROW][COL], int row, int col);//打印棋盤(pán)
void Player_go(char arr[ROW][COL], int row, int col);//玩家走
void Computer_walk(char arr[ROW][COL], int row, int col);//電腦走
char Judge_win(char arr[ROW][COL], int row, int col);//判斷輸贏

#endif // GAME_H__


test.c //包含主函數(shù),函數(shù)調(diào)用

#define _CRT_SECURE_NO_WARNINGS 1

#include "game.h"

void menu() //菜單函數(shù)
{
 printf("********************\n");
 printf("**** 1.play ****\n");
 printf("**** 0.exit ****\n");
 printf("********************\n");
}

void game() //游戲函數(shù)
{
 char arr[ROW][COL] = { 0 };
 Arr_init(arr, ROW, COL); //數(shù)組初始化
 Print_che(arr, ROW, COL); //打印棋盤(pán)
 while(1)
 {
 char n;
 Computer_walk(arr, ROW, COL); //電腦走
 Print_che(arr, ROW, COL);
 n = Judge_win(arr, ROW, COL); //判斷輸贏
 if (n == 'X') //根據(jù)判斷輸贏函數(shù)所返回的值做出不同的選擇
 {
 printf("玩家贏\n");
 break;
 }
 else if (n == '0')
 {
 printf("電腦贏\n");
 break;
 }
 else if (n == 'Q')
 {
 printf("平局\n");
 break;
 }
 else
 printf("----------------\n");

 Player_go(arr, ROW, COL);//玩家走
 Print_che(arr, ROW, COL);
 n = Judge_win(arr, ROW, COL);//判斷輸贏
 if (n == 'X')
 {
 printf("玩家贏\n");
 break;
 }
 else if (n == '0')
 {
 printf("電腦贏\n");
 break;
 }
 else if (n == 'Q')
 printf("平局\n");
 else
 printf("------------------\n");
 }
}

void test() //游戲流程函數(shù)
{
 int input = 0;
 srand((unsigned)time(NULL));
 do
 {
 menu();
 printf("請(qǐng)輸入選擇:");
 scanf("%d", &input);
 switch (input)
 {
 case 1:
 game();
 break;
 case 0:
 break;
 default:
 printf("輸入錯(cuò)誤,請(qǐng)重新輸入。\n");
 }
 } while (input);
}

int main()
{
 test();
 system("pause");
 return 0;
}

game.c //包含函數(shù)的定義

#include "game.h"

void Arr_init(char arr[ROW][COL], int row, int col)//數(shù)組初始化
{
 int i = 0;
 int j = 0;
 for(i = 0; i < row; i++)
 {
 for(j = 0; j < col; j++)
 arr[i][j] = ' ';
 }
}

void Print_che(char arr[ROW][COL], int row, int col)//打印棋盤(pán)
{
 int i, j;
 for(i = 0; i < row; i++)
 {
 for(j = 0; j < col; j++)
 {
 printf(" %c ", arr[i][j]);
 if (j < col - 1)
 printf("|");
 }
 printf("\n");
 for(j = 0; j < col ; j++)
 {
 if (i < row - 1)
 printf("___");
 else
 printf(" ");
 if (j < col - 1)
 printf("|");
 }
 printf("\n");
 }
}

void Player_go(char arr[ROW][COL], int row, int col) //玩家走
{
 int x, y;
 printf("請(qǐng)玩家輸入坐標(biāo):");
 while (1)
 {
 scanf("%d %d", &x, &y);
 if ((x > 0 && x <= row + 1) && (y > 0 && y <= col + 1)) //判斷坐標(biāo)正確性
 {
 if (arr[x - 1][y - 1] == ' ')
 {
 arr[x - 1][y - 1] = 'X';
 break;
 }
 else
 printf("輸入錯(cuò)誤,請(qǐng)重新輸入:");
 }
 else
 printf("輸入錯(cuò)誤,請(qǐng)重新輸入:");
 }
}

void Computer_walk(char arr[ROW][COL], int row, int col) //電腦走
{
 int x, y;
 printf("請(qǐng)電腦輸入坐標(biāo)\n");
 while(1)
 {
 x = rand() % row; //生成隨機(jī)數(shù)
 y = rand() % col;
 if (arr[x][y] == ' ') //判斷坐標(biāo)正確性
 {
 arr[x][y] = '0';
 break;
 }
 }
}

char Judge_win(char arr[ROW][COL], int row, int col) //判斷輸贏
{
 int i, j;
 int count = 0;
 for (i = 0; i < row; i++)
 {
 if (arr[i][0] == arr[i][1] && arr[i][1] == arr[i][2] && arr[i][0] != ' ') //行相等
 return arr[i][1];
 if (arr[0][i] == arr[1][i] && arr[1][i] == arr[2][i] && arr[0][i] != ' ') //列相等
 return arr[1][i];
 if (arr[0][0] == arr[1][1] && arr[1][1] == arr[2][2] && arr[1][1] != ' ') //正斜相等
 return arr[1][1];
 if (arr[0][2] == arr[1][1] && arr[1][1] == arr[2][0] && arr[1][1] != ' ') //反斜相等
 return arr[1][1];
 }
 for (i = 0; i < row; i++)//平局
 {
 for (j = 0; j < col; j++)
 {
 if (arr[i][j] == 'X' || arr[i][j] == '0') //遍歷數(shù)組,查看是否還有沒(méi)有走的地方
 {
 count++;
 if (count == 9)
 return 'Q';
 }
 }
 }
 return 'A';
}

到這里,我們的程序已經(jīng)完成了,我們看看程序的效果

以上就是一個(gè)簡(jiǎn)單的三子棋程序,多有不足之處,還望指教。

更多有趣的經(jīng)典小游戲?qū)崿F(xiàn)專(zhuān)題,分享給大家:

C++經(jīng)典小游戲匯總

python經(jīng)典小游戲匯總

python俄羅斯方塊游戲集合

JavaScript經(jīng)典游戲 玩不停

java經(jīng)典小游戲匯總

javascript經(jīng)典小游戲匯總

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

相關(guān)文章

  • C語(yǔ)言中關(guān)于動(dòng)態(tài)內(nèi)存分配的詳解

    C語(yǔ)言中關(guān)于動(dòng)態(tài)內(nèi)存分配的詳解

    動(dòng)態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存。棧上分配的內(nèi)存是由系統(tǒng)分配和釋放的,空間有限,在復(fù)合語(yǔ)句或函數(shù)運(yùn)行結(jié)束后就會(huì)被系統(tǒng)自動(dòng)釋放而堆上分配的內(nèi)存則不會(huì)有這個(gè)問(wèn)題。
    2021-09-09
  • C語(yǔ)言實(shí)現(xiàn)點(diǎn)菜系統(tǒng)

    C語(yǔ)言實(shí)現(xiàn)點(diǎn)菜系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)點(diǎn)菜系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C語(yǔ)言對(duì)組文件處理的相關(guān)函數(shù)小結(jié)

    C語(yǔ)言對(duì)組文件處理的相關(guān)函數(shù)小結(jié)

    這篇文章主要介紹了C語(yǔ)言對(duì)組文件處理的相關(guān)函數(shù)小結(jié),包括setgrent()函數(shù)和getgrent()函數(shù)以及endgrent()函數(shù),需要的朋友可以參考下
    2015-08-08
  • C語(yǔ)言數(shù)據(jù)的存儲(chǔ)詳解

    C語(yǔ)言數(shù)據(jù)的存儲(chǔ)詳解

    本文詳細(xì)講解了C語(yǔ)言數(shù)據(jù)的存儲(chǔ),文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • Qt使用QChart實(shí)現(xiàn)靜態(tài)顯示溫度變化曲線

    Qt使用QChart實(shí)現(xiàn)靜態(tài)顯示溫度變化曲線

    QChart模塊是Qt?Charts庫(kù)的基礎(chǔ),提供了用于創(chuàng)建和顯示各種類(lèi)型圖表的類(lèi)和接口,本文主要介紹了如何使用QChart實(shí)現(xiàn)動(dòng)態(tài)顯示3個(gè)設(shè)備的溫度變化曲線,感興趣的可以了解一下
    2023-06-06
  • C語(yǔ)言?struct結(jié)構(gòu)體超詳細(xì)講解

    C語(yǔ)言?struct結(jié)構(gòu)體超詳細(xì)講解

    C語(yǔ)言中,結(jié)構(gòu)體類(lèi)型屬于一種構(gòu)造類(lèi)型(其他的構(gòu)造類(lèi)型還有:數(shù)組類(lèi)型,聯(lián)合類(lèi)型),下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言結(jié)構(gòu)體(struct)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • C 創(chuàng)建鏈表并將信息存儲(chǔ)在二進(jìn)制文件中讀取的實(shí)例代碼

    C 創(chuàng)建鏈表并將信息存儲(chǔ)在二進(jìn)制文件中讀取的實(shí)例代碼

    C 創(chuàng)建鏈表并將信息存儲(chǔ)在二進(jìn)制文件中讀取的實(shí)例代碼,需要的朋友可以參考一下
    2013-03-03
  • 舉例講解C語(yǔ)言的fork()函數(shù)創(chuàng)建子進(jìn)程的用法

    舉例講解C語(yǔ)言的fork()函數(shù)創(chuàng)建子進(jìn)程的用法

    fork函數(shù)是Linux下一個(gè)近乎專(zhuān)有的C語(yǔ)言函數(shù),因?yàn)槭褂脮r(shí)需要調(diào)用unistd.h這個(gè)頭文件,這里我們就在Linux環(huán)境下舉例講解C語(yǔ)言的fork()函數(shù)創(chuàng)建子進(jìn)程的用法,需要的朋友可以參考下
    2016-06-06
  • C++實(shí)現(xiàn)紅黑樹(shù)應(yīng)用實(shí)例代碼

    C++實(shí)現(xiàn)紅黑樹(shù)應(yīng)用實(shí)例代碼

    紅黑樹(shù)它一種特殊的二叉查找樹(shù),這意味著它滿足二叉查找樹(shù)的特征,但是也有許多自己的特性,這篇文章主要給大家介紹了關(guān)于C++實(shí)現(xiàn)紅黑樹(shù)的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • C++實(shí)現(xiàn)幸運(yùn)大抽獎(jiǎng)(QT版)

    C++實(shí)現(xiàn)幸運(yùn)大抽獎(jiǎng)(QT版)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)幸運(yùn)大抽獎(jiǎng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01

最新評(píng)論