2025.11.17 力扣每日一题

1437.是否所有1都至少相隔k个元素

cpp 复制代码
class Solution {
public:
    bool kLengthApart(vector<int>& nums, int k) {
        // cnt:记录当前位置与上一个1之间的"间隔元素数"
        // 初始化为k:处理第一个1的情况(第一个1前面没有元素,默认满足间隔要求)
        int cnt = k;
        
        // 遍历数组的每个元素
        for (int num : nums) {
            if (num == 0) {
                // 当前是0,间隔数+1
                cnt++;
                continue; // 跳过后续逻辑,继续下一个元素
            }
            
            // 当前是1:检查与上一个1的间隔是否≥k
            if (cnt < k) {
                return false; // 间隔不足,直接返回false
            }
            
            // 重置间隔数:当前1是新的"上一个1",后续元素从0开始计数间隔
            cnt = 0;
        }
        
        // 遍历完所有元素,所有1的间隔都满足要求
        return true;
    }
};

为什么初始化为 k?

假设 cnt 初始化为 0,会出现什么问题?

当第一个元素是 1 时,代码会检查 cnt < k(即 0 < k)。如果 k ≥ 1,会直接返回 false,这显然错误(第一个 1 不需要间隔)。

而初始化为 k 时:

当第一个元素是 1 时,代码检查 cnt < k(即 k < k),结果为 false,不会误判,而是正常重置 cnt=0,开始统计与下一个 1 的间隔。

即使 k=0(允许 1 相邻),初始化为 0 也满足 cnt >= 0,逻辑依然正确。

相关推荐
夏鹏今天学习了吗1 天前
【LeetCode热题100(87/100)】最小路径和
算法·leetcode·职场和发展
哈哈不让取名字1 天前
基于C++的爬虫框架
开发语言·c++·算法
Lips6111 天前
2026.1.20力扣刷题笔记
笔记·算法·leetcode
2501_941329721 天前
YOLOv8-LADH马匹检测识别算法详解与实现
算法·yolo·目标跟踪
洛生&1 天前
Planets Queries II(倍增,基环内向森林)
算法
小郭团队1 天前
1_6_五段式SVPWM (传统算法反正切+DPWM2)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·matlab·dsp开发
小郭团队1 天前
1_7_五段式SVPWM (传统算法反正切+DPWM3)算法理论与 MATLAB 实现详解
开发语言·嵌入式硬件·算法·matlab·dsp开发
鱼跃鹰飞1 天前
Leetcode347:前K个高频元素
数据结构·算法·leetcode·面试
bybitq1 天前
LeetCode236-二叉树的最近公共祖先(LCA)问题详解-C++
算法·深度优先
啊阿狸不会拉杆1 天前
《数字图像处理》第 7 章 - 小波与多分辨率处理
图像处理·人工智能·算法·计算机视觉·数字图像处理