C++實現(xiàn)簡易的五子棋小游戲
更新時間:2022年05月05日 16:20:14 作者:Prepare_y
這篇文章主要為大家詳細介紹了C++實現(xiàn)簡易的五子棋小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C++實現(xiàn)簡易五子棋小游戲的具體代碼,供大家參考,具體內(nèi)容如下
游戲界面:


這是一個簡易的五子棋游戲,由c語言編寫,每次循環(huán)輸入兩個位置的坐標,通過其奇偶性判斷是黑子還是白子,之后再判斷是否可以滿足勝利的條件,可以的話輸出**勝,接著進行下一步的操作。同時,每次進行操作會在數(shù)組里記錄下來位置,這樣每次刷新屏幕時就可以顯示正常的棋子位置情況,如果游戲結(jié)束,則將數(shù)組更新,實現(xiàn)重新開始的功能。
下面是代碼:
#include <cstdio>
#include <cstdlib>
#include <windows.h>
using namespace std;
void init_wel();//初始化界面
int bla=1,whr,x,y,poi_ch[20][20];//判斷棋子的種類
int Map();//棋盤
int put_ch(int m,int n);//放置棋子
int judge();//判斷是否有一方勝利
int main()
{
? ? memset(poi_ch,0,sizeof(poi_ch));
? ? init_wel();//初始化
? ? Map();
? ? while(1)//實現(xiàn)了游戲的循環(huán)進行
? ? {
? ? ? ? whr=1;
? ? ? ? scanf("%d%d",&x,&y);
? ? ? ? poi_ch[x][y]=put_ch(x,y);
? ? ? ? Map();
? ? ? ? bla++;
? ? ? ? judge();
? ? ? ? if(!whr)
? ? ? ? {
? ? ? ? ? ? memset(poi_ch,0,sizeof(poi_ch));
? ? ? ? ? ? bla=1;
? ? ? ? ? ? Map();
? ? ? ? }
? ? }
? ? return 0;
}
void init_wel()//初始化進入界面
{
? ? for(int i=0; i<5; i++)
? ? ? ? printf(". . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . \n");
? ? printf(". . . . . . . . . . . . . . Hello. .Boys and Girls . ?. . . . . . . . . . . . . . . .\n");
? ? for(int i=0; i<5; i++)
? ? ? ? printf(". . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . \n");
? ? system("pause");//實現(xiàn)了一個按任意鍵繼續(xù)的功能
}
int Map()//每次都實現(xiàn)刷新操作
{
? ? system("cls");
? ? for(int j=0; j<20; j++)
? ? {
? ? ? ? poi_ch[0][j]=j;
? ? ? ? printf("%3d",poi_ch[0][j]);
? ? }
? ? printf("\n");
? ? for(int i=1; i<20; i++)
? ? {
? ? ? ? for(int j=0; j<20; j++)
? ? ? ? {
?
? ? ? ? ? ? if(j==0)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? poi_ch[i][0]=i;
? ? ? ? ? ? ? ? printf("%3d",poi_ch[i][0]);
? ? ? ? ? ? }
? ? ? ? ? ? else if (i>0&&j>0)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? if(poi_ch[i][j]==0)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? printf(" ?*");
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? if(poi_ch[i][j]==21)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? printf(" ●");
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? if(poi_ch[i][j]==22)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? printf(" ○");
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? printf("\n");
? ? }
? ? return 0;
}
int put_ch(int m,int n)//放置棋子
{
? ? if(bla%2==1&&poi_ch[m][n]==0)
? ? {
? ? ? ? poi_ch[m][n]=21;
? ? ? ? return poi_ch[m][n];
? ? }
? ? else
? ? {
? ? ? ? if(poi_ch[m][n]==21)
? ? ? ? {
? ? ? ? ? ? bla--;
? ? ? ? ? ? return poi_ch[m][n];
? ? ? ? }
? ? ? ? if(poi_ch[m][n]==22)
? ? ? ? {
? ? ? ? ? ? bla--;
? ? ? ? ? ? return poi_ch[m][n];
? ? ? ? }
? ? }
? ? if(bla%2==0&&poi_ch[m][n]==0)
? ? {
? ? ? ? poi_ch[m][n]=22;
? ? ? ? return poi_ch[m][n];
?
? ? }
? ? else
? ? {
? ? ? ? if(poi_ch[m][n]==21)
? ? ? ? {
? ? ? ? ? ? bla--;
? ? ? ? ? ? return poi_ch[m][n];
? ? ? ? }
? ? ? ? if(poi_ch[m][n]==22)
? ? ? ? {
? ? ? ? ? ? bla--;
? ? ? ? ? ? return poi_ch[m][n];
? ? ? ? }
? ? }
? ? return 0;
}
int judge()//對于最終的結(jié)果進行判斷
{
? ? for(int i=1; i<20; i++)
? ? {
? ? ? ? for(int j=1; j<20; j++)
? ? ? ? {
? ? ? ? ? ? if(poi_ch[i][j]==21&&poi_ch[i][j+1]==21&&poi_ch[i][j+2]==21&&poi_ch[i][j+3]==21&&poi_ch[i][j+4]==21)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? whr=0;
? ? ? ? ? ? ? ? printf("白子勝\n");
? ? ? ? ? ? ? ? system("pause");
? ? ? ? ? ? ? ? break;
? ? ? ? ? ? }
? ? ? ? ? ? if(poi_ch[i][j]==22&&poi_ch[i][j+1]==22&&poi_ch[i][j+2]==22&&poi_ch[i][j+3]==22&&poi_ch[i][j+4]==22)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? whr=0;
? ? ? ? ? ? ? ? printf("黑子勝\n");
? ? ? ? ? ? ? ? system("pause");
? ? ? ? ? ? ? ? break;
? ? ? ? ? ? }
? ? ? ? ? ? if(poi_ch[i][j]==21&&poi_ch[i+1][j]==21&&poi_ch[i+2][j]==21&&poi_ch[i+3][j]==21&&poi_ch[i+4][j]==21)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? whr=0;
? ? ? ? ? ? ? ? printf("白子勝\n");
? ? ? ? ? ? ? ? system("pause");
? ? ? ? ? ? ? ? break;
? ? ? ? ? ? }
? ? ? ? ? ? if(poi_ch[i][j]==22&&poi_ch[i+1][j]==22&&poi_ch[i+2][j]==22&&poi_ch[i+3][j]==22&&poi_ch[i+4][j]==22)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? whr=0;
? ? ? ? ? ? ? ? printf("黑子勝\n");
? ? ? ? ? ? ? ? system("pause");
? ? ? ? ? ? ? ? break;
? ? ? ? ? ? }
? ? ? ? ? ? if(poi_ch[i][j]==21&&poi_ch[i+1][j+1]==21&&poi_ch[i+2][j+2]==21&&poi_ch[i+3][j+3]==21&&poi_ch[i+4][j+4]==21)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? whr=0;
? ? ? ? ? ? ? ? printf("白子勝\n");
? ? ? ? ? ? ? ? system("pause");
? ? ? ? ? ? ? ? break;
? ? ? ? ? ? }
? ? ? ? ? ? if(poi_ch[i][j]==22&&poi_ch[i+1][j-1]==22&&poi_ch[i+2][j-2]==22&&poi_ch[i+3][j-3]==22&&poi_ch[i+4][j-4]==22)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? whr=0;
? ? ? ? ? ? ? ? printf("黑子勝\n");
? ? ? ? ? ? ? ? system("pause");
? ? ? ? ? ? ? ? break;
? ? ? ? ? ? }
? ? ? ? }
? ? }
? ? return 0;
}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言結(jié)構(gòu)體內(nèi)存的對齊知識詳解
這篇文章主要介紹了C語言結(jié)構(gòu)體內(nèi)存的對齊的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-03-03
將CString字符串輸入轉(zhuǎn)化成整數(shù)的實現(xiàn)方法
下面小編就為大家?guī)硪黄獙String字符串輸入轉(zhuǎn)化成整數(shù)的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09

