用Deepseek写一个五子棋微信小程序

news2025/4/22 2:34:32

在当今快节奏的生活中,休闲小游戏成为了许多人放松心情的好选择。五子棋作为一款经典的策略游戏,不仅规则简单,还能锻炼思维。最近,我借助 DeepSeek 的帮助,开发了一款五子棋微信小程序。在这篇文章中,我将分享整个开发过程,包括与 DeepSeek 的对话、代码实现思路以及最终的成果。

1. 初识 DeepSeek:从需求到实现 

一开始,我对如何实现一个五子棋小程序并没有太多头绪。于是,我向 DeepSeek 提出了需求:

我:用微信小程序帮我写一个五子棋,要求功能和思路清晰。

DeepSeek 很快给出了一个清晰的实现思路和代码示例。它建议使用一个二维数组来表示棋盘,并通过点击事件实现落子功能。此外,它还提供了胜负判断的逻辑,确保游戏能够正常运行。 

2. 代码实现:从零到一

2.1 棋盘与落子 

 DeepSeek 提供的代码中,棋盘用一个 15x15 的二维数组表示,每个元素代表棋盘上的一个交叉点。0 表示空位,1 表示黑子,2 表示白子。玩家点击棋盘时,程序会根据点击的位置更新数组,并在界面上显示对应的棋子。

// 初始化棋盘
initBoard() {
  const board = new Array(15);
  for (let i = 0; i < 15; i++) {
    board[i] = new Array(15).fill(0);
  }
  this.setData({ board });
}

2.2 胜负判断

 每次落子后,程序会检查当前落子的位置是否形成五子连珠。DeepSeek 提供了一个高效的检查函数,通过遍历四个方向(水平、垂直、对角线、反对角线)来判断是否有五子连珠。

// 检查是否胜利
checkWin(row, col, player) {
  const { board } = this.data;
  const directions = [
    [1, 0], // 水平
    [0, 1], // 垂直
    [1, 1], // 对角线
    [1, -1] // 反对角线
  ];

  for (let [dx, dy] of directions) {
    let count = 1;
    for (let i = 1; i < 5; i++) {
      if (board[row + i * dx] && board[row + i * dx][col + i * dy] === player) {
        count++;
      } else {
        break;
      }
    }
    for (let i = 1; i < 5; i++) {
      if (board[row - i * dx] && board[row - i * dx][col - i * dy] === player) {
        count++;
      } else {
        break;
      }
    }
    if (count >= 5) return true;
  }
  return false;
}

2.3 添加 AI 对手

为了让游戏更具挑战性,我向 DeepSeek 提出了新的需求:

我:帮我增加AI对手功能。

 DeepSeek 很快给出了一个基于规则的 AI 实现。AI 会优先阻止玩家获胜,并尝试自己获胜。它的逻辑如下:

  1. 如果 AI 可以形成五子连珠,直接获胜。

  2. 如果玩家可以形成五子连珠,AI 会阻止。

  3. 如果 AI 可以形成四子连珠,优先落子。

  4. 如果玩家可以形成四子连珠,AI 会阻止。

  5. 随机选择一个空位落子。

// AI 落子逻辑
findBestMove(board) {
  // 优先级1:AI 可以形成五子连珠
  for (let i = 0; i < 15; i++) {
    for (let j = 0; j < 15; j++) {
      if (board[i][j] === 0 && this.checkPotentialWin(i, j, 2)) {
        return { row: i, col: j };
      }
    }
  }

  // 优先级2:阻止玩家形成五子连珠
  for (let i = 0; i < 15; i++) {
    for (let j = 0; j < 15; j++) {
      if (board[i][j] === 0 && this.checkPotentialWin(i, j, 1)) {
        return { row: i, col: j };
      }
    }
  }

  // 其他优先级...
}

3. 与 DeepSeek 的对话:从问题到解决方案

在整个开发过程中,DeepSeek 不仅提供了代码,还解释了每一步的逻辑。例如,当我询问如何实现 AI 时,它详细说明了 AI 的优先级规则,并提供了相应的代码片段。这种交互式的学习方式让我对五子棋的实现有了更深的理解。

4. 最终成果:一款优雅的五子棋小程序

经过与 DeepSeek 的合作,我成功开发了一款五子棋微信小程序。它的主要功能包括:

  • 双人对战:玩家可以和朋友一起对战。

  • 人机对战:玩家可以与 AI 对战,AI 具备一定的智能。

  • 胜负判断:实时判断游戏结果,并显示胜利信息。

  • 重新开始:游戏结束后,可以一键重置棋盘

附:完整代码

首先,创建一个微信小程序项目,项目结构如下:

five-in-a-row/
├── pages/
│   ├── index/
│   │   ├── index.js
│   │   ├── index.wxml
│   │   ├── index.wxss
│   │   └── index.json
├── app.js
├── app.json
├── app.wxss
└── project.config.json

index.wxml - 棋盘界面 

<view class="container">
  <view class="board">
    <block wx:for="{{board}}" wx:for-item="row" wx:for-index="i">
      <view class="row">
        <block wx:for="{{row}}" wx:for-item="cell" wx:for-index="j">
          <view class="cell" bindtap="onTap" data-row="{{i}}" data-col="{{j}}">
            <view class="stone {{cell === 1 ? 'black' : (cell === 2 ? 'white' : '')}}"></view>
          </view>
        </block>
      </view>
    </block>
  </view>
  <view class="status">{{status}}</view>
</view>

index.wxss - 样式

 

.container {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px;
}

.board {
  display: flex;
  flex-direction: column;
  border: 1px solid #000;
}

.row {
  display: flex;
}

.cell {
  width: 40px;
  height: 40px;
  border: 1px solid #000;
  display: flex;
  justify-content: center;
  align-items: center;
}

.stone {
  width: 30px;
  height: 30px;
  border-radius: 50%;
}

.black {
  background-color: black;
}

.white {
  background-color: white;
  border: 1px solid #000;
}

.status {
  margin-top: 20px;
  font-size: 20px;
}

index.js - 逻辑代码

Page({
  data: {
    board: [], // 棋盘
    currentPlayer: 1, // 当前玩家,1表示黑子,2表示白子
    status: '黑子先下', // 游戏状态
    gameOver: false // 游戏是否结束
  },

  onLoad() {
    this.initBoard();
  },

  // 初始化棋盘
  initBoard() {
    const board = new Array(15);
    for (let i = 0; i < 15; i++) {
      board[i] = new Array(15).fill(0);
    }
    this.setData({
      board,
      currentPlayer: 1,
      status: '黑子先下',
      gameOver: false
    });
  },

  // 点击棋盘事件
  onTap(e) {
    if (this.data.gameOver) return;

    const { row, col } = e.currentTarget.dataset;
    const { board, currentPlayer } = this.data;

    if (board[row][col] !== 0) return; // 该位置已经有棋子

    board[row][col] = currentPlayer;
    this.setData({ board });

    if (this.checkWin(row, col, currentPlayer)) {
      this.setData({
        status: currentPlayer === 1 ? '黑子胜利!' : '白子胜利!',
        gameOver: true
      });
      return;
    }

    const nextPlayer = currentPlayer === 1 ? 2 : 1;
    this.setData({
      currentPlayer: nextPlayer,
      status: nextPlayer === 1 ? '黑子下' : '白子下'
    });
  },

  // 检查是否胜利
  checkWin(row, col, player) {
    const { board } = this.data;
    const directions = [
      [1, 0], // 水平
      [0, 1], // 垂直
      [1, 1], // 对角线
      [1, -1] // 反对角线
    ];

    for (let [dx, dy] of directions) {
      let count = 1;
      for (let i = 1; i < 5; i++) {
        if (board[row + i * dx] && board[row + i * dx][col + i * dy] === player) {
          count++;
        } else {
          break;
        }
      }
      for (let i = 1; i < 5; i++) {
        if (board[row - i * dx] && board[row - i * dx][col - i * dy] === player) {
          count++;
        } else {
          break;
        }
      }
      if (count >= 5) return true;
    }
    return false;
  },

  // 重新开始游戏
  restartGame() {
    this.initBoard();
  }
});

 运行效果

  • 打开微信开发者工具,导入项目。

  • 运行后,你会看到一个15x15的棋盘,玩家可以点击棋盘上的交叉点落子。

  • 游戏会实时判断是否有五子连珠,如果有则显示胜利信息。

  • 游戏结束后,可以通过调用 restartGame 方法重新开始游戏。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2312894.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MWC 2025 | 紫光展锐与中国联通联合发布5G eSIM 平板

2025 年 3 月 3 日至 6 日&#xff0c;在全球移动通信行业的年度盛会 —— 世界移动通信大会&#xff08;MWC 2025&#xff09;上&#xff0c;紫光展锐联合中国联通重磅发布了支持eSIM的5G平板VN300E。 该产品采用紫光展锐T9100高性能5G SoC芯片平台&#xff0c;内置8 TOPS算力…

操作系统控制台-健康守护我们的系统

引言基本准备体验功能健康守护系统诊断 收获提升结语 引言 阿里云操作系统控制平台作为新一代云端服务器中枢平台&#xff0c;通过创新交互模式重构主机管理体验。操作系统控制台提供了一系列管理功能&#xff0c;包括运维监控、智能助手、扩展插件管理以及订阅服务等。用户可以…

FreeRTOS任务状态查询

一.任务相关API vTaskList&#xff08;&#xff09;&#xff0c;创建一个表格描述每个任务的详细信息 char biaoge[1000]; //定义一个缓存 vTaskList(biaoge); //将表格存到这缓存中 printf("%s /r/n",biaoge); 1.uxTaskPriorityGet&#xff08;&#xf…

blender学习25.3.6

【02-基础篇】Blender小凳子之凳面及凳脚的创作_哔哩哔哩_bilibili 【03-基础篇】Blender小凳子之其他细节调整优化_哔哩哔哩_bilibili 这篇文章写的全&#xff0c;不用自己写了 Blender 学习笔记&#xff08;一&#xff09;快捷键记录_blender4.1快捷键-CSDN博客 shifta&a…

RabbitMQ 2025/3/5

高性能异步通信组件。 同步调用 以支付为例&#xff1a; 可见容易发生雪崩。 异步调用 以支付为例&#xff1a; 支付服务当甩手掌柜了&#xff0c;不管后面的几个服务的结果。只管库库发&#xff0c;后面那几个服务想取的时候就取&#xff0c;因为消息代理里可以一直装&#x…

JSP+Servlet实现对数据库增删改查功能

前提概要 需要理解的重要概念 ​MVC模式&#xff1a; Model&#xff08;person类&#xff09;&#xff1a;数据模型View&#xff08;JSP&#xff09;&#xff1a;显示界面Controller&#xff08;Servlet&#xff09;&#xff1a;处理业务逻辑 ​请求流程&#xff1a; 浏览器 …

C++【类和对象】

类和对象 1.this 指针2.类的默认成员函数3.构造函数4.析构函数5.拷贝构造函数 1.this 指针 接上文 this指针存在内存的栈区域。 2.类的默认成员函数 定义&#xff1a;编译器自动生成的成员函数。一个类&#xff0c;我们不写的情况下会默认生成六个成员函数。 3.构造函数 函…

GStreamer —— 2.13、Windows下Qt加载GStreamer库后运行 - “教程13:播放控制“(附:完整源码)

运行效果(音频) 简介 上一个教程演示了GStreamer工具。本教程介绍视频播放控制。快进、反向播放和慢动作都是技术 统称为 Trick Modes&#xff0c;它们都有一个共同点 修改 Normal playback rate。本教程介绍如何实现 这些效果并在交易中添加了帧步进。特别是&#xff0c;它 显…

MongoDB winx64 msi包安装详细教程

首先我们可以从官网上选择对应版本和对应的包类型进行安装&#xff1a; 下载地址&#xff1a;Download MongoDB Community Server | MongoDB 这里可以根据自己的需求&#xff0c; 这里我选择的是8.0.5 msi的版本&#xff0c;采用的传统装软件的方式安装。无需配置命令。 下载…

WinUI 3 支持的三种窗口 及 受限的窗口透明

我的目标 希望能够熟悉 WinUI 3 窗口的基本使用方式&#xff0c;了解可能出现的问题 。 WinUI 3 支持三种窗口模式&#xff0c;分别为&#xff1a;常规窗口模式、画中画模式、全屏模式。 窗口模式&#xff1a;常规 即我们最常见的普通窗口。 支持&#xff1a;显示最大化按钮…

如何借助 ArcGIS Pro 高效统计基站 10km 范围内的村庄数量?

在当今数字化时代&#xff0c;地理信息系统&#xff08;GIS&#xff09;技术在各个领域都发挥着重要作用。 特别是在通信行业&#xff0c;对于基站周边覆盖范围内的地理信息分析&#xff0c;能够帮助我们更好地进行网络规划、资源分配以及市场分析等工作。 今天&#xff0c;就…

Linux网络之数据链路层协议

目录 数据链路层 MAC地址与IP地址 数据帧 ARP协议 NAT技术 代理服务器 正向代理 反向代理 上期我们学习了网络层中的相关协议&#xff0c;为IP协议。IP协议通过报头中的目的IP地址告知了数据最终要传送的目的主机的IP地址&#xff0c;从而指引了数据在网络中的一步…

如何使用 PyInstaller 打包 Python 脚本?一看就懂的完整教程!

PyInstaller 打包指令教程 1. 写在前面 通常&#xff0c;在用 Python 编写完一个脚本后&#xff0c;需要将它部署并集成到一个更大的项目中。常见的集成方式有以下几种&#xff1a; 使用 PyInstaller 打包。使用 Docker 打包。将 Python 嵌入到 C 代码中&#xff0c;并封装成…

解锁DeepSpeek-R1大模型微调:从训练到部署,打造定制化AI会话系统

目录 1. 前言 2.大模型微调概念简述 2.1. 按学习范式分类 2.2. 按参数更新范围分类 2.3. 大模型微调框架简介 3. DeepSpeek R1大模型微调实战 3.1.LLaMA-Factory基础环境安装 3.1大模型下载 3.2. 大模型训练 3.3. 大模型部署 3.4. 微调大模型融合基于SpirngBootVue2…

Hadoop、Hive、Spark的关系

Part1&#xff1a;Hadoop、Hive、Spark关系概览 1、MapReduce on Hadoop 和spark都是数据计算框架&#xff0c;一般认为spark的速度比MR快2-3倍。 2、mapreduce是数据计算的过程&#xff0c;map将一个任务分成多个小任务&#xff0c;reduce的部分将结果汇总之后返回。 3、HIv…

基于VMware虚拟机的Ubuntu22.04系统安装和配置(新手保姆级教程)

文章目录 一、前期准备1. 硬件要求2. 软件下载2-1. 下载虚拟机运行软件 二、安装虚拟机三、创建 Ubuntu 系统虚拟机四、Ubuntu 系统安装过程的配置五、更换国内镜像源六、设置静态 IP七、安装常用软件1. 编译工具2. 代码管理工具3. 安装代码编辑软件&#xff08;VIM&#xff09…

基于SpringBoot的历史馆藏系统设计与实现(源码+SQL脚本+LW+部署讲解等)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

蓝桥杯[每日两题] 真题:好数 神奇闹钟 (java版)

题目一&#xff1a;好数 题目描述 一个整数如果按从低位到高位的顺序&#xff0c;奇数位&#xff08;个位、百位、万位 &#xff09;上的数字是奇数&#xff0c;偶数位&#xff08;十位、千位、十万位 &#xff09;上的数字是偶数&#xff0c;我们就称之为“好数”。给定…

基于BMO磁性细菌优化的WSN网络最优节点部署算法matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 5.完整程序 1.程序功能描述 无线传感器网络&#xff08;Wireless Sensor Network, WSN&#xff09;由大量分布式传感器节点组成&#xff0c;用于监测物理或环境状况。节点部署是 WSN 的关键问…

学习笔记:Python网络编程初探之基本概念(一)

一、网络目的 让你设备上的数据和其他设备上进行共享&#xff0c;使用网络能够把多方链接在一起&#xff0c;然后可以进行数据传递。 网络编程就是&#xff0c;让在不同的电脑上的软件能够进行数据传递&#xff0c;即进程之间的通信。 二、IP地址的作用 用来标记唯一一台电脑…