用Deepseek写一个五子棋微信小程序
在当今快节奏的生活中,休闲小游戏成为了许多人放松心情的好选择。五子棋作为一款经典的策略游戏,不仅规则简单,还能锻炼思维。最近,我借助 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 会优先阻止玩家获胜,并尝试自己获胜。它的逻辑如下:
-
如果 AI 可以形成五子连珠,直接获胜。
-
如果玩家可以形成五子连珠,AI 会阻止。
-
如果 AI 可以形成四子连珠,优先落子。
-
如果玩家可以形成四子连珠,AI 会阻止。
-
随机选择一个空位落子。
// 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方法重新开始游戏。

相关文章:
用Deepseek写一个五子棋微信小程序
在当今快节奏的生活中,休闲小游戏成为了许多人放松心情的好选择。五子棋作为一款经典的策略游戏,不仅规则简单,还能锻炼思维。最近,我借助 DeepSeek 的帮助,开发了一款五子棋微信小程序。在这篇文章中,我将…...
AF3 squeeze_features函数解读
AlphaFold3 data_transforms 模块的 squeeze_features 函数的作用去除 蛋白质特征张量中不必要的单维度(singleton dimensions)和重复维度,以使其适配 AlphaFold3 预期的输入格式。 源代码: def squeeze_features(protein):&qu…...
Python 远程抓取服务器日志最后 1000行
哈喽,大家好,我是木头左! 一、神奇的 Python 工具箱 1. SSH 连接的密钥——paramiko paramiko 库提供了丰富的方法来处理 SSH 连接的各种细节。从创建连接对象,到执行远程命令,再到获取命令输出,它都能有…...
vue3+screenfull实现部分页面全屏(遇到的问题会持续更新)
需求:除了左侧菜单,右侧主体部分全部全屏 首先下载screenfull全屏插件 npm install screenfull --save页面引入 import screenfull from screenfull;我这里是右上角全屏图标 <el-iconref"elIconRef"color"#ffffff"size"2…...
Ubuntu 下 nginx-1.24.0 源码分析 (1)
main 函数在 src\core\nginx.c int ngx_cdecl main(int argc, char *const *argv) {ngx_buf_t *b;ngx_log_t *log;ngx_uint_t i;ngx_cycle_t *cycle, init_cycle;ngx_conf_dump_t *cd;ngx_core_conf_t *ccf;ngx_debug_init(); 进入 main 函数 最…...
2025数据存储技术风向标:解析数据湖与数据仓库的实战效能差距
一、技术演进的十字路口 当前全球数据量正以每年65%的复合增长率激增,IDC预测到2027年企业将面临日均处理500TB数据的挑战。在这样的背景下,传统数据仓库与新兴数据湖的博弈进入白热化阶段。Gartner最新报告显示,采用混合架构的企业数据运营效…...
探索高性能AI识别和边缘计算 | NVIDIA Jetson Orin Nano 8GB 开发套件的全面测评
随着边缘计算和人工智能技术的迅速发展,性能强大的嵌入式AI开发板成为开发者和企业关注的焦点。NVIDIA近期推出的Jetson Orin Nano 8GB开发套件,凭借其40 TOPS算力、高效的Ampere架构GPU以及出色的边缘AI能力,引起了广泛关注。本文将从配置性…...
数据结构 常见的排序算法
🌻个人主页:路飞雪吖~ 🌠专栏:数据结构 目录 🌻个人主页:路飞雪吖~ 一、插入排序 🌟直接插入排序 🌟希尔排序 二、选择排序 🌟选择排序 🌟堆排序…...
ES索引知识
索引是数据的载体,存储了文档和映射的信息 索引是具有相同结构的文档的合集体。 设置索引,不仅仅是设置索引名字,还有索引的一些配置,比如:分片和副本,刷新频率,搜索结果的最大参数,…...
FreeRTOS第17篇:FreeRTOS链表实现细节05_MiniListItem_t:FreeRTOS内存优化
文/指尖动听知识库-星愿 文章为付费内容,商业行为,禁止私自转载及抄袭,违者必究!!! 文章专栏:深入FreeRTOS内核:从原理到实战的嵌入式开发指南 1 为什么需要迷你列表项? 在嵌入式系统中,内存资源极其宝贵。FreeRTOS为满足不同场景需求,设计了标准列表项(ListItem_…...
Golang | Gin(简洁版)
文章目录 安装使用RESTful API响应页面获取请求参数路由讲解中间件 安装使用 Gin 是一个 golang 的微框架,封装比较优雅,API 友好,源代码比较明确。具有快速灵活,容错方便等特点。其实对于 golang 而言,web 框架的依赖…...
RAG外挂知识库
目录 RAG的工作流程 python实现RAG 1.引入相关库及相关准备工作 函数 1. 加载并读取文档 2. 文档分割 3. embedding 4. 向集合中添加文档 5. 用户输入内容 6. 查询集合中的文档 7. 构建Prompt并生成答案 主流程 附录 函数解释 1. open() 函数语法 2.client.embe…...
Rust语言:开启高效编程之旅
目录 一、Rust 语言初相识 二、Rust 语言的独特魅力 2.1 内存安全:消除隐患的护盾 2.2 高性能:与 C/C++ 并肩的实力 2.3 强大的并发性:多线程编程的利器 2.4 跨平台性:适配多环境的优势 三、快速上手 Rust 3.1 环境搭建:为开发做准备 3.2 第一个 R…...
蓝桥杯备考:图论初解
1:图的定义 我们学了线性表和树的结构,那什么是图呢? 线性表是一个串一个是一对一的结构 树是一对多的,每个结点可以有多个孩子,但只能有一个父亲 而我们今天学的图!就是多对多的结构了 V表示的是图的顶点集…...
Codeforces Round 502 E. The Supersonic Rocket 凸包、kmp
题目链接 题目大意 平面上给定两个点集,判定两个点集分别形成的凸多边形能否通过旋转、平移重合。 点集大小 ≤ \leq ≤ 1 0 5 10^{5} 105,坐标范围 [0, 1 0 8 10^{8} 108 ]. 思路 题意很明显,先求出凸包再判断两凸包是否同构。这里用…...
机器人匹诺曹机制,真话假话平衡机制
摘要: 本文聚焦于机器人所采用的一种“匹诺曹机制”,该机制旨在以大概率保持“虚拟鼻子”(一种象征虚假程度的概念)不会过长,通过在对话中夹杂真话与假话来实现。文章深入探讨了这一机制的原理,分析其背后的…...
用Python分割并高效处理PDF大文件
在处理大型PDF文件时,将它们分解成更小、更易于管理的块通常是有益的。这个过程称为分区,它可以提高处理效率,并使分析或操作文档变得更容易。在本文中,我们将讨论如何使用Python和为Unstructured.io库将PDF文件划分为更小的部分。…...
【RAG】混合检索(Hybrid Search) 提高检索精度
1.问题:向量检索也易混淆,而关键字会更精准 在实际生产中,传统的关键字检索(稀疏表示)与向量检索(稠密表示)各有利弊。 举个具体例子,比如文档中包含很长的专有名词, 关…...
CTFHub-FastCGI协议/Redis协议
将木马进行base64编码 <?php eval($_GET[cmd]);?> 打开kali虚拟机,使用虚拟机中Gopherus-master工具 Gopherus-master工具安装 git clone https://github.com/tarunkant/Gopherus.git 进入工具目录 cd Gopherus 使用工具 python2 "位置" --expl…...
【算法day4】最长回文子串——动态规划方法
最长回文子串 给你一个字符串 s,找到 s 中最长的 回文 子串。 https://leetcode.cn/problems/longest-palindromic-substring/submissions/607962358/ 动态规划: 回文串即是从前面开始读和从后面开始读,读出来的字符串均相同的字符串&#…...
idea大量爆红问题解决
问题描述 在学习和工作中,idea是程序员不可缺少的一个工具,但是突然在有些时候就会出现大量爆红的问题,发现无法跳转,无论是关机重启或者是替换root都无法解决 就是如上所展示的问题,但是程序依然可以启动。 问题解决…...
【大模型RAG】Docker 一键部署 Milvus 完整攻略
本文概要 Milvus 2.5 Stand-alone 版可通过 Docker 在几分钟内完成安装;只需暴露 19530(gRPC)与 9091(HTTP/WebUI)两个端口,即可让本地电脑通过 PyMilvus 或浏览器访问远程 Linux 服务器上的 Milvus。下面…...
Golang dig框架与GraphQL的完美结合
将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用,可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器,能够帮助开发者更好地管理复杂的依赖关系,而 GraphQL 则是一种用于 API 的查询语言,能够提…...
C++ 基础特性深度解析
目录 引言 一、命名空间(namespace) C 中的命名空间 与 C 语言的对比 二、缺省参数 C 中的缺省参数 与 C 语言的对比 三、引用(reference) C 中的引用 与 C 语言的对比 四、inline(内联函数…...
Module Federation 和 Native Federation 的比较
前言 Module Federation 是 Webpack 5 引入的微前端架构方案,允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...
实现弹窗随键盘上移居中
实现弹窗随键盘上移的核心思路 在Android中,可以通过监听键盘的显示和隐藏事件,动态调整弹窗的位置。关键点在于获取键盘高度,并计算剩余屏幕空间以重新定位弹窗。 // 在Activity或Fragment中设置键盘监听 val rootView findViewById<V…...
有限自动机到正规文法转换器v1.0
1 项目简介 这是一个功能强大的有限自动机(Finite Automaton, FA)到正规文法(Regular Grammar)转换器,它配备了一个直观且完整的图形用户界面,使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...
C# 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...
网站指纹识别
网站指纹识别 网站的最基本组成:服务器(操作系统)、中间件(web容器)、脚本语言、数据厍 为什么要了解这些?举个例子:发现了一个文件读取漏洞,我们需要读/etc/passwd,如…...
JVM虚拟机:内存结构、垃圾回收、性能优化
1、JVM虚拟机的简介 Java 虚拟机(Java Virtual Machine 简称:JVM)是运行所有 Java 程序的抽象计算机,是 Java 语言的运行环境,实现了 Java 程序的跨平台特性。JVM 屏蔽了与具体操作系统平台相关的信息,使得 Java 程序只需生成在 JVM 上运行的目标代码(字节码),就可以…...
