0

0

高效统计与1相邻的唯一0元素数量——二维数组边界零点计数算法教程

碧海醫心

碧海醫心

发布时间:2026-02-22 09:21:18

|

612人浏览过

|

来源于php中文网

原创

高效统计与1相邻的唯一0元素数量——二维数组边界零点计数算法教程

本文介绍一种健壮、无越界风险的算法,用于统计二维二进制数组中所有与至少一个1正交相邻(上/下/左/右)的不重复0元素个数,并提供可直接运行的Java实现与关键细节解析。

本文介绍一种健壮、无越界风险的算法,用于统计二维二进制数组中**所有与至少一个1正交相邻(上/下/左/右)的不重复0元素个数**,并提供可直接运行的java实现与关键细节解析。

在处理二维二进制数组(仅含0和1)时,一个常见但易出错的需求是:找出所有“被1包围”的0——即该0的正交四邻域(上下左右)中至少存在一个1,且每个满足条件的0仅计1次,即使它被多个1同时邻接。注意:题目明确要求去重统计(如一个0同时邻接两个1,仍只算1个),且必须规避 ArrayIndexOutOfBoundsException。

直接遍历1并检查其邻居(如提问者初始思路)虽直观,但极易因边界处理不当导致越界;而若改用遍历所有0再检查邻域,则逻辑更清晰、边界更易控制,且天然支持去重(每个0只被访问一次)。

✅ 推荐解法:遍历每个0,检查其四邻是否含1

核心思想:对数组中每个位置 (r, c),若 nums[r][c] == 0,则检查其上 (r-1,c)、下 (r+1,c)、左 (r,c-1)、右 (r,c+1) 四个方向是否存在合法索引且值为1。只要任一方向满足,该0即计入结果,随后立即跳出当前检查(避免重复累加同一0)。

此方法优势显著:

Pix2Pix
Pix2Pix

使用Prompt编辑视频

下载
  • 零越界风险:每次访问邻居前均校验行列索引有效性;
  • 天然去重:每个0最多被计1次;
  • 时间复杂度最优:O(m×n),每个元素仅访问常数次;
  • 空间复杂度极低:仅需 O(1) 额外空间。

以下是完整、鲁棒的 Java 实现:

public static int borderZeros(int[][] nums) {
    // 边界校验:空数组或单元素数组直接返回0
    if (nums == null || nums.length == 0) return 0;
    int rows = nums.length;
    int cols = nums[0].length;
    if (rows <= 0 || cols <= 0) return 0;

    int count = 0;
    // 遍历每一个单元格
    for (int r = 0; r < rows; r++) {
        for (int c = 0; c < cols; c++) {
            if (nums[r][c] == 0) { // 找到一个0
                boolean adjacentToOne = false;
                // 检查上、下、左、右四个方向
                if (r > 0 && nums[r-1][c] == 1) adjacentToOne = true;      // 上
                if (r < rows-1 && nums[r+1][c] == 1) adjacentToOne = true; // 下
                if (c > 0 && nums[r][c-1] == 1) adjacentToOne = true;      // 左
                if (c < cols-1 && nums[r][c+1] == 1) adjacentToOne = true;  // 右

                if (adjacentToOne) count++;
            }
        }
    }
    return count;
}

? 验证示例输出

  • nums1(4×8数组):算法正确返回 10
  • nums2(6×6数组):算法正确返回 18

你可将上述方法嵌入主程序测试:

public static void main(String[] args) {
    int[][] nums1 = {
        {0, 0, 1, 0, 1, 0, 1, 0},
        {1, 0, 0, 0, 0, 0, 0, 0},
        {0, 0, 0, 0, 0, 0, 0, 0},
        {0, 0, 0, 0, 0, 0, 0, 0},
    };
    int[][] nums2 = {
        {0, 0, 0, 0, 1, 1},
        {0, 1, 0, 0, 1, 0},
        {0, 1, 0, 0, 0, 0},
        {0, 1, 0, 0, 0, 0},
        {0, 1, 0, 0, 1, 0},
        {0, 0, 0, 0, 1, 1},
    };

    System.out.println(borderZeros(nums1)); // 输出: 10
    System.out.println(borderZeros(nums2)); // 输出: 18
}

⚠️ 关键注意事项

  • 勿混淆方向逻辑:题目明确排除对角线(如 (r-1,c-1)),仅检查正交四邻;
  • 边界判断顺序不可颠倒:务必先检查索引合法性(如 r > 0),再访问数组(如 nums[r-1][c]),否则短路求值失效会导致越界;
  • 无需额外数据结构:本题不要求记录具体位置或路径,纯计数场景下布尔标记 + 即时计数是最简方案;
  • 图论视角补充说明:虽然答案提及“二分图最大匹配”,但该模型适用于更复杂的关联约束(如一对一配对),而本题本质是存在性判定(∃邻1)+ 集合去重,直接遍历远比建图+匈牙利算法更简洁高效,切勿过度工程化。

掌握此模式后,你可轻松迁移至类似问题:如统计“被障碍物包围的空地”、“与污染源相邻的安全区”等网格邻域分析任务。核心原则始终如一:以目标元素为锚点,安全检查其邻域,用最小开销达成语义准确。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

543

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

27

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

39

2026.01.06

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

461

2023.08.14

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

928

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

307

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

183

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

29

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

103

2026.02.13

热门下载

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

精品课程

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

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