探讨C++中巧妙的边界条件处理:以花坛种花问题为例【巧妙思想、边界条件】

news/2024/8/26 20:22:33 标签: c++, 开发语言, 算法, 贪心算法, 数组

算法题中,处理数组的边界条件是一个常见的挑战。特别是在涉及多条件判断时,如何高效且清晰地处理边界问题,可以显著提升代码的简洁性和可读性。本文将以一道经典的算法题——花坛种花问题,来探讨边界条件的巧妙处理方法。

问题描述

605. 种花问题 - 力扣(LeetCode)

给定一个由 0 和 1 组成的整数数组 flowerbed,0 表示该位置没有种花,1 表示该位置已经种花。花不能种在相邻的地块上,即不能有两个相邻的1。再给定一个整数 n,问是否能在不打破规则的情况下种入 n 朵花。

示例

  • 输入:flowerbed = [1, 0, 0, 0, 1], n = 1
    • 输出:true
  • 输入:flowerbed = [1, 0, 0, 0, 1], n = 2
    • 输出:false

解题思路

  1. 遍历花坛数组:我们需要遍历数组flowerbed,找出每一个可以种花的位置。
  2. 判断当前位置是否可以种花:对于每一个位置i,我们检查它的前后位置(i-1i+1)是否为空(即是否为0)。这里需要特别注意数组的边界情况:
    • 如果i是第一个位置,我们只需检查i+1
    • 如果i是最后一个位置,我们只需检查i-1
  3. 种花并更新计数器:如果当前位置可以种花,我们就在当前位置种花,并将计数器n减1。
  4. 判断是否完成任务:如果在遍历过程中,n变为0,说明可以成功种植n朵花,返回true。如果遍历结束后n仍然大于0,返回false

巧妙的边界条件处理

在实现过程中,有一个非常精妙的边界条件处理方法,即通过如下判断来确保前后位置的检查不会越界:

bool emptyLeft = (i == 0) || (flowerbed[i - 1] == 0);
bool emptyRight = (i == length - 1) || (flowerbed[i + 1] == 0);

这段代码通过简单的逻辑运算符,巧妙地处理了边界条件,避免了常见的越界错误。以下是详细的解释:

  1. 前位置检查

    • i == 0:如果i是第一个位置,那么它没有前一个位置,所以直接视为前位置为空。
    • flowerbed[i - 1] == 0:如果i不是第一个位置,检查i-1位置是否为空。
  2. 后位置检查

    • i == length - 1:如果i是最后一个位置,那么它没有后一个位置,所以直接视为后位置为空。
    • flowerbed[i + 1] == 0:如果i不是最后一个位置,检查i+1位置是否为空。

常见的边界条件处理

通常情况下,当我们处理数组的边界条件时,会采用如下方式:

if (i > 0 && flowerbed[i - 1] == 0) {
    // 处理前一个位置
}

if (i < length - 1 && flowerbed[i + 1] == 0) {
    // 处理后一个位置
}

这种方式需要多次检查i是否越界,虽然能够保证程序的正确性,但显得繁琐且冗长。相比之下,上述巧妙的边界条件处理方式则显得更为简洁:

  • 简洁性:通过逻辑运算符将边界条件和内容检查结合在一起,减少了代码行数。
  • 可读性:代码更加直观,易于理解,减少了不必要的复杂性。
  • 执行效率:减少了多余的判断,优化了执行流程。

代码实现

下面是完整的代码实现:

class Solution {
public:
    bool canPlaceFlowers(vector<int>& flowerbed, int n) {
        int cnt = 0;
        for (int i = 0; i < flowerbed.size(); i++) {
            if ((flowerbed[i] == 0) && (i == 0 || flowerbed[i - 1] == 0) &&
                (i == flowerbed.size() - 1 || flowerbed[i + 1] == 0)) {
                flowerbed[i] = 1;
                cnt++;
            }
            if(cnt >= n){
                return true;
            }
        }
        return cnt >= n;
    }
};

总结

通过上述代码和分析,我们可以看到,巧妙的边界条件处理不仅让代码更简洁明了,而且减少了潜在的错误。希望这篇文章能帮助我们更好地理解边界条件的处理方法,并将这种技巧应用到其他算法问题中。


http://www.niftyadmin.cn/n/5558928.html

相关文章

供应链管理(SCM):如何在颜值和体验上发力

要在供应链管理系统&#xff08;SCM&#xff09;中在颜值和体验上发力&#xff0c;让用户感觉耳目一新&#xff0c;可以采取以下措施&#xff1a; 界面设计优化&#xff1a; 对供应链管理系统的界面进行优化&#xff0c;注重界面的美观、简洁和易用性。采用现代化的设计风格、…

vue复制链接操作

vue复制链接操作 使用clipboardclipboard属性代码实现 发布测试出现问题问题分析解决方案最终代码实现document.execCommand扩展常用例子 给要复制的文本或者按钮加上点击事件后&#xff0c;并将要复制的值传过来 使用clipboard clipboard属性 –解释read从剪贴板读取数据&a…

朴素模式匹配算法与KMP算法(非重点)

目录 一. 朴素模式匹配算法1.1 什么是字符串的匹配模式1.2 朴素模式匹配算法1.3 通过数组下标实现朴素模式匹配算法 二. KMP算法2.1 算法分析2.2 用代码实现&#xff08;只会出现在选择题&#xff0c;考察代码的概率不大&#xff09; 三. 手算next数组四. KMP算法的进一步优化4…

深度学习-1-如何从零搭建神经网络TensorFlow和Keras

参考TensorFlow的网络模型简要概述 快速入门 TensorFlow2 模型部署 参考如何从零搭建神经网络?一份万能搭建神经网络的通用框架! 1 从零搭建神经网络的流程 从零搭建神经网络的流程图,可以用于搭建和训练各种类型的神经网络,包括但不限CNN、RNN、GAN、自动编码器,提供了…

基于Python+Flask+SQLite的豆瓣电影可视化系统

FlaskMySQLEcharts 基于PythonFlaskSQLite的豆瓣电影可视化系统 Echarts 不支持登录注册&#xff0c;并且信息存储在数据库中 不含爬虫代码&#xff0c;或爬虫代码已失效 简介 基于PythonFlaskMySQL的豆瓣电影可视化系统&#xff0c;采用Echart构建图表&#xff0c;支持自定…

编译x-Wrt 全过程

参考自;​​​​​​c编译教程 | All about X-Wrt 需要详细了解的小伙伴还请参看原文 ^-^ 概念&#xff1a; x-wrt&#xff08;基于openwrt深度定制的发行版本&#xff09; 编译系统: ubuntu22.04 注意&#xff1a; 特别注意的是&#xff0c;整个编译过程&#xff0c;都是用 …

陪玩系统小程序模式APP小程序H5系统搭建开发

随着移动互联网的营及和游戏行业的蓬轨发展&#xff0c;陪玩服务应远而生并迅速唱起&#xff0c;陪玩系统小程序作为连接游戏玩家与陪玩师的桥梁&#xff0c;其模式系统的搭建与开发是得尤为重要&#xff0c;本文将洋细凰述陪玩系统小程宗模式系统的搭建开发流程&#xff0c;包…

Hadoop3:HDFS-集群安全模式

一、基本介绍 1、安全模式 文件系统只接受读数据请求&#xff0c;而不接受删除、修改等变更请求 2、 二、进入安全模式场景 1、NameNode在加载镜像文件和编辑日志期间处于安全模式&#xff08;就是启动集群的时候&#xff09;&#xff1b; 2、NameNode再接收DataNode注册时…