使用linux,c++,创作一个简单的五子棋游戏

2024-04-24 00:44

本文主要是介绍使用linux,c++,创作一个简单的五子棋游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#include <iostream>  
#include <vector>  
#include <unordered_map>  using namespace std;  // 棋盘大小  
const int BOARD_SIZE = 15;  // 棋子类型  
enum ChessType {  EMPTY,  BLACK,  WHITE  
};  // 棋盘类  
class ChessBoard {  
private:  vector<vector<ChessType>> board;  public:  ChessBoard() {  board.resize(BOARD_SIZE, vector<ChessType>(BOARD_SIZE, EMPTY));  }  // 打印棋盘  void print() {  for (int i = 0; i < BOARD_SIZE; ++i) {  for (int j = 0; j < BOARD_SIZE; ++j) {  switch (board[i][j]) {  case BLACK: cout << "● "; break;  case WHITE: cout << "○ "; break;  default: cout << "· "; break;  }  }  cout << endl;  }  }  // 下棋  bool placeChess(ChessType type, int x, int y) {  if (x < 0 || x >= BOARD_SIZE || y < 0 || y >= BOARD_SIZE || board[x][y] != EMPTY) {  return false;  }  board[x][y] = type;  return true;  }  // 检查是否胜利  bool checkWin(ChessType type, int x, int y) {  // 检查八个方向(上下左右,四个对角线)  vector<pair<int, int>> directions = {{-1, 0}, {1, 0}, {0, -1}, {0, 1},  {-1, -1}, {-1, 1}, {1, -1}, {1, 1}};  for (auto dir : directions) {  int count = 1;  for (int i = 1; i < 5; ++i) {  int nx = x + i * dir.first;  int ny = y + i * dir.second;  if (nx >= 0 && nx < BOARD_SIZE && ny >= 0 && ny < BOARD_SIZE && board[nx][ny] == type) {  ++count;  } else {  break;  }  }  for (int i = 1; i < 5; ++i) {  int nx = x - i * dir.first;  int ny = y - i * dir.second;  if (nx >= 0 && nx < BOARD_SIZE && ny >= 0 && ny < BOARD_SIZE && board[nx][ny] == type) {  ++count;  } else {  break;  }  }  if (count >= 5) {  return true;  }  }  return false;  }  
};  int main() {  ChessBoard board;  ChessType currentPlayer = BLACK;  bool gameOver = false;  while (!gameOver) {  board.print();  cout << (currentPlayer == BLACK ? "Black" : "White") << ", enter your move (x y): ";  int x, y;  cin >> x >> y;  if (board.placeChess(currentPlayer, x, y)) {  if (board.checkWin(currentPlayer, x, y)) {  board.print();  cout << (currentPlayer == BLACK ? "Black wins!" : "White wins!") << endl;  gameOver = true;  } else {  currentPlayer = (currentPlayer == BLACK) ? WHITE : BLACK;  }  } else {  cout << "Invalid move. Try again." << endl;  }  }  return 0;  
}

编译通过后的执行效果:

这篇关于使用linux,c++,创作一个简单的五子棋游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/930331

相关文章

linux生产者,消费者问题

pthread_cond_wait() :用于阻塞当前线程,等待别的线程使用pthread_cond_signal()或pthread_cond_broadcast来唤醒它。 pthread_cond_wait() 必须与pthread_mutex 配套使用。pthread_cond_wait()函数一进入wait状态就会自动release mutex。当其他线程通过pthread

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

关于C++中的虚拟继承的一些总结(虚拟继承,覆盖,派生,隐藏)

1.为什么要引入虚拟继承 虚拟继承是多重继承中特有的概念。虚拟基类是为解决多重继承而出现的。如:类D继承自类B1、B2,而类B1、B2都继承自类A,因此在类D中两次出现类A中的变量和函数。为了节省内存空间,可以将B1、B2对A的继承定义为虚拟继承,而A就成了虚拟基类。实现的代码如下: class A class B1:public virtual A; class B2:pu

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

C++的模板(八):子系统

平常所见的大部分模板代码,模板所传的参数类型,到了模板里面,或实例化为对象,或嵌入模板内部结构中,或在模板内又派生了子类。不管怎样,最终他们在模板内,直接或间接,都实例化成对象了。 但这不是唯一的用法。试想一下。如果在模板内限制调用参数类型的构造函数会发生什么?参数类的对象在模板内无法构造。他们只能从模板的成员函数传入。模板不保存这些对象或者只保存他们的指针。因为构造函数被分离,这些指针在模板外

Java五子棋之坐标校正

上篇针对了Java项目中的解构思维,在这篇内容中我们不妨从整体项目中拆解拿出一个非常重要的五子棋逻辑实现:坐标校正,我们如何使漫无目的鼠标点击变得有序化和可控化呢? 目录 一、从鼠标监听到获取坐标 1.MouseListener和MouseAdapter 2.mousePressed方法 二、坐标校正的具体实现方法 1.关于fillOval方法 2.坐标获取 3.坐标转换 4.坐

Linux 安装、配置Tomcat 的HTTPS

Linux 安装 、配置Tomcat的HTTPS 安装Tomcat 这里选择的是 tomcat 10.X ,需要Java 11及更高版本 Binary Distributions ->Core->选择 tar.gz包 下载、上传到内网服务器 /opt 目录tar -xzf 解压将解压的根目录改名为 tomat-10 并移动到 /opt 下, 形成个人习惯的路径 /opt/tomcat-10

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

C++工程编译链接错误汇总VisualStudio

目录 一些小的知识点 make工具 可以使用windows下的事件查看器崩溃的地方 dumpbin工具查看dll是32位还是64位的 _MSC_VER .cc 和.cpp 【VC++目录中的包含目录】 vs 【C/C++常规中的附加包含目录】——头文件所在目录如何怎么添加,添加了以后搜索头文件就会到这些个路径下搜索了 include<> 和 include"" WinMain 和

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode