主頁 > 軟體設計 > C++開發控制臺小游戲之旅(2)——《五子棋》

C++開發控制臺小游戲之旅(2)——《五子棋》

2020-09-30 20:26:54 軟體設計

歡迎光臨

相信每一位學編程的朋友,都曾有一顆游戲夢想,希望能親手打造出屬於自己的游戲!

如果我可以創作一款結合AR技術的、如**動漫《游戲王》**中那樣進行決鬥的游戲,該有多好!

游戲背景

《五子棋》這款游戲,從我讀小學起就經常在玩,與小夥伴們一起在課餘時間一決高下,不亦樂乎!曾經的美好,只留下回憶,但我相信我的人生始終會與快樂相伴……

如今我萌發心思,欲抽空發展一下愛好,自己動手逐步打造出一款可玩的小游戲,同時也為廣大游戲編程愛好者們提供略微的參考,一起爲了夢想而前行!

本游戲采用純C++語言進行編寫,可在Windows控制臺Linux終端運行,
使用Visual StudioGCC進行編譯即可,
游戲內操作均通過鍵盤輸入達成,簡單易上手,
全部源碼檔案僅有1個,直接複製粘貼到本地即可輕鬆完成編譯構建,生產可執行程式並開啓游戲,

注:游戲源碼在頁面底部,


若諸位喜歡《五子棋》,並希望改善游戲體驗(如期待後續增加的游戲功能、玩法等),可在留言區添加評論,進行吐槽或提供寶貴建議(如發現游戲bug),亦可添加作者微信、QQ,
相互交流,共同進步!
我將認真回復並虛心學習,感謝諸位!

我的聯係方式
QQ:1575335819
微信:CS-huo

游戲截圖

開始游戲

錯誤提示

游戲結束

游戲特色

  • 背景故事
  • 自定義地圖大小
  • 花式字體顔色

後續待完善

  • Bug修復
  • AI敵人

源代碼

#include <iostream>
#include <string>
#ifdef _WIN32
#include <Windows.h>
#endif // _WIN32
using namespace std;


typedef struct Point
{
	int row;
	int col;

	Point() { row = 0; col = 0; }

	Point(int r, int c) 
	{
		row = r;
		col = c;
	}
} Map;


static Map map;
static Point point;
static char **arr;


void setColor(int n);
void restoreColor();
void startGame();
void endGame();
void tellStory();
void initMap();
void playerRound(int n);
bool isValidRowCol(const Map &m);
bool isValid(const Point &p);
bool win(int n);
void showBoard();


int main()
{
	startGame();
}

#ifdef _WIN32
void setColor(int n)
{
	WORD attr;
	if (n == 31) attr = FOREGROUND_RED;
	else if (n == 34) attr = FOREGROUND_BLUE;
	else if (n > 30 && n < 39) attr = FOREGROUND_GREEN;
	else if (n == 41) attr = BACKGROUND_RED;
	else if (n == 42) attr = BACKGROUND_GREEN;
	else if (n > 40 && n < 49) attr = BACKGROUND_BLUE;

	SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), attr);
}

void restoreColor()
{
	SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), FOREGROUND_INTENSITY);
}
#endif	// WIN32
#ifdef __linux
void setColor(int n)
{
	cout << "\033[" << to_string(n) + "m";
}
	
void restoreColor()
{
	cout << "\033[39m";
	cout << "\033[49m";
}
#endif	// __linux

void startGame()
{
	string info = "五子棋游戲開始!";
	setColor(31);
	cout << info << endl;
	restoreColor();
	
	// Tell story
	tellStory();

	// Initialize the map by player
	initMap();

	// Play round, use a loop to control the game
	for (int i = 0; i < 10000; ++i)
	{
		playerRound(i%2+1);
	}
}

void endGame()
{
	string info = "勝負已分,游戲結束!";
	setColor(31);
	cout << endl << info << endl;
	restoreColor();

	// Exit the process
	exit(0);
}

void tellStory()
{
	string story = "滾滾長江東逝水,浪花淘儘英雄,是非成敗轉頭空,青山依舊在,幾度夕陽紅,\n"
		"一代五子棋天才少年——江流兒,欲與棋聖林心誠一決高下!今天就是他倆的決鬥之日……";
	setColor(32);
	cout << story << endl << endl;
	restoreColor();
}

void initMap()
{
	// Initialize the map by player
	setColor(34);
	cout << "初始化地圖,請輸入網格地圖行列數……" << endl;

	setColor(31);
	do 
	{
		cout << "網格地圖行數:";
		cin >> map.row;
		cout << "網格地圖列數:";
		cin >> map.col;
	} while (!isValidRowCol(map));

	// Create board, assign to array
	arr = new char*[map.row];
	for (int i = 0; i < map.row; ++i)
	{
		arr[i] = new char[map.col];
		for (int j = 0; j < map.col; ++j)
		{
			arr[i][j] = '-';
		}
	}

	setColor(31);
	cout << "各位棋手,地圖初始化已完成,游戲正式啓動!" << endl;
	restoreColor();

	// Show the chess board
	showBoard();
}

void playerRound(int n)
{
	string info = "輪到棋手" + to_string(n) + "的回合!";
	setColor(31);
	cout << info << endl;

	// Input the position of chess
	setColor(32);
	do 
	{
		cout << "請決定棋子放置位置……" << endl;
		cout << "行:";
		cin >> point.row;
		cout << "列:";
		cin >> point.col;
	} while (!isValid(point));
	restoreColor();

	// Set chess
	arr[point.row-1][point.col-1] = (n == 1 ? 'X' : 'O');

	// Judge win
	bool res = win(n);
	if (res)
	{
		setColor(31);
		cout << "恭喜棋手" << to_string(n) << "取得了本局勝利!" << endl;
		restoreColor();

		showBoard();
		endGame();
	}

	// Show the board
	showBoard();
}

bool isValidRowCol(const Map &m)
{
	if (m.row > 0 && m.col > 0 && m.row < 100 && m.col < 100) return true;
	return false;
}

bool isValid(const Point &p)
{
	int r = p.row-1, c = p.col-1;

	if (r < 0 || c < 0 || r >= map.row || c >= map.col) 
	{
		setColor(31);
		cout << "不可在此位置擺放棋子,請再三考慮!" << endl;
		restoreColor();
		return false;
	}

	if (arr[r][c] == '-') return true;
	else 
	{
		setColor(31);
		cout << "不可在此位置擺放棋子,請再三考慮!" << endl;
		restoreColor();
	}

	return false;
}

bool win(int n)
{
#define CLEAR	\
	count = 0;	\
	last = tmp = '-';

#define JUDGE	\
	{	\
	tmp = arr[i][j];	\
	if (tmp == '-' || last != tmp) count = 0;	\
	last = tmp;	\
	++count;	\
	if (count >= 5) return true;	\
	}

	int count = 0;
	char last = '-';
	char tmp = '-';

	for (int i = 0; i < map.row; ++i)
	{
		CLEAR
		for (int j = 0; j < map.col; ++j) JUDGE
	}

	for (int i = -1; i < map.row; ++i)
	{
		CLEAR
		int j = -1;
		while (++j < map.col && ++i < map.row) JUDGE
	}

	for (int j = 0; j < map.col; ++j)
	{
		CLEAR
		for (int i = 0; i < map.row; ++i) JUDGE
	}

	for (int j = -1; j < map.col; ++j)
	{
		CLEAR
		int i = -1;
		while (++i < map.row && ++j < map.col) JUDGE
	}

	return false;
#undef CLEAR
#undef JUDGE
}

void showBoard()
{
	string info = "當前棋盤格局為:";
	setColor(34);
	cout << endl << info << endl;
	
	// Show chess board
	setColor(32);
	for (int i = 0; i < map.row; ++i)
	{
		for (int j = 0; j < map.col; ++j)
		{
			cout << " " << arr[i][j];
		}
		cout << endl;
	}
	restoreColor();
}


轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/143159.html

標籤:其他

上一篇:codeforces1426 E. Rock, Paper, Scissors(思維 || 最小費用最大流)

下一篇:[演算法系列]遞回應用——二叉樹(2):一種帶資訊遞回回傳的求解方式

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more