0

0

标题:在 8×8 五子连珠式井字棋中高效检测对角线与多方向获胜条件的完整实现

花韻仙語

花韻仙語

发布时间:2026-01-19 16:57:11

|

348人浏览过

|

来源于php中文网

原创

标题:在 8×8 五子连珠式井字棋中高效检测对角线与多方向获胜条件的完整实现

本文详解如何在 8×8 网格的扩展井字棋(需连续 5 子获胜)中,准确、高效地检测所有可能获胜路径——包括横向、纵向、主对角线(左上→右下)和副对角线(右上→左下),避免边界越界与重复计算。

在传统 3×3 井字棋中,获胜判定逻辑简单;但当网格扩大至 8×8 且胜利条件升级为“任意方向连续 5 子同色”时(即类五子棋规则),暴力遍历所有可能起始点+全方向扫描极易出错——尤其常见问题如:仅检测主对角线却忽略副对角线、未校验坐标合法性导致 ArrayIndexOutOfBoundsException、或从固定起点硬编码循环(如 for (int row=0; row

核心设计思想是:以落子位置为锚点,动态判断其是否可能成为某条长度为 5 的获胜序列的起点,并仅对合法方向执行增量检查。这不仅大幅提升效率(O(1) 平均单次判定),更彻底规避边缘遗漏。

以下为关键实现逻辑(基于一维数组优化的二维映射):

static int side = 8;
static int toWin = 5;
static int[] fields = new int[side * side]; // 'x' → -1, 'o' → 1, empty → 0

private static int gameOver(int idx) {
    if (fields[idx] == 0) return 0;

    int row = idx / side;
    int col = idx % side;

    // 预判各方向是否可容纳 5 连子(避免越界)
    boolean canRight   = col + toWin <= side;           // 横向:向右延伸
    boolean canDown    = row + toWin <= side;           // 纵向:向下延伸
    boolean canRightDown = canRight && canDown;         // 主对角线(↘)
    boolean canLeftDown  = (col + 1) >= toWin && canDown; // 副对角线(↙),即 col ≥ toWin-1

    // 四方向检查:使用 lambda 定义步进函数,复用 check() 逻辑
    return (canRight   && check(idx, toWin, i -> i + 1)      ||
            canDown    && check(idx, toWin, i -> i + side)   ||
            canRightDown && check(idx, toWin, i -> i + side + 1) ||
            canLeftDown  && check(idx, toWin, i -> i + side - 1))
           ? fields[idx] : 0;
}

private static boolean check(int start, int len, IntUnaryOperator next) {
    int val = fields[start];
    for (int i = 1; i < len; i++) {
        start = next.applyAsInt(start);
        if (start < 0 || start >= fields.length || fields[start] != val) {
            return false;
        }
    }
    return true;
}

优势说明

MaxAI
MaxAI

MaxAI.me是一款功能强大的浏览器AI插件,集成了多种AI模型。

下载
  • 精准锚定:每次只从最新落子位置出发判断,无需全局扫描,时间复杂度从 O(n²) 降至 O(1) 单次调用;
  • 安全边界:canRight/canDown 等布尔标志在进入 check() 前完成数学验证(如 col + toWin
  • 方向正交:覆盖全部 4 个获胜方向(横、纵、主对角、副对角),其中副对角线通过 col >= toWin - 1 判断左边界可行性;
  • 可扩展强:仅需修改 side 和 toWin 即可适配任意尺寸棋盘与连胜数(如 15×15 五子棋、10×10 六子棋)。

⚠️ 注意事项

  • 若使用 JButton[][] buttons 二维结构,请在 gameOver() 中将 (row, col) 映射为一维索引:idx = row * side + col;
  • 避免直接比较 Color.RED 等对象引用(易因 UI 渲染差异失败),推荐为每个按钮维护独立状态枚举(如 Player.RED, Player.GREEN);
  • 字符串拼接(如 red.concat("+"))效率低下且不适用于动态长度判定——应改用计数器或布尔标记(如 streak = 0; if (match) streak++; else streak = 0;)。

综上,该方案以“落子驱动、方向预检、增量验证”为原则,兼顾正确性、性能与可维护性,是大型网格化连珠类游戏获胜判定的工业级实践范式。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

751

2023.08.22

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

258

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

208

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1468

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

620

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

550

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

545

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

164

2025.07.29

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

12

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 5万人学习

Rust 教程
Rust 教程

共28课时 | 4.6万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号