2025.11.13 力扣每日一题

3228.将1移动到末尾的最大操作次数

cpp 复制代码
class Solution {
public:
    int maxOperations(string s) {
      int countOne = 0;
      int ans = 0;
      for(int i = 0;i<s.length();i++){
        if(s[i] == '0'){
            while((i+1)<s.length()&&s[i+1]=='0'){
                i++;
            }
            ans += countOne;
        }else{
            countOne++;
        }
      }
      return ans;
    }
};

这段代码的核心思路是通过统计每个连续0区间左侧的1数量,来计算最大操作次数,我们可以分步骤拆解:

1. 变量定义

  • countOne:记录当前遍历位置左侧的1的数量 (这些1会参与后续0的操作计数)。
  • ans:记录最终的最大操作次数。

2. 遍历逻辑

代码遍历字符串s,分两种情况处理:

情况 1:遇到'0'
  • 先通过while循环跳过连续的0 (因为连续的0属于同一个 "可被操作的区间",只需统计一次左侧的1数量)。
  • 然后执行 ans += countOne:当前0区间的每个0会被左侧所有1各操作一次,因此操作次数累加countOne
情况 2:遇到'1'
  • 执行 countOne++:更新左侧1的数量,供后续0区间统计使用。

3. 题目逻辑对应

  • 连续的0被视为一个 "区间",只需统计一次左侧的1数量(所以用while跳过连续0)。
  • 每个0区间的操作次数是countOne(左侧所有1的数量),因此累加countOneans

示例验证(以题目示例s = "1001101"为例)

字符串拆解为:1001101

  • 遇到第一个'1'countOne = 1
  • 遇到"00"区间:ans += 1(此时ans=1),然后跳过连续的0
  • 遇到"11"区间:countOne依次变为23
  • 遇到"0"区间:ans += 3(此时ans=4),跳过连续0(这里只有一个0,无跳过)。
  • 遇到最后一个'1'countOne变为4(但无后续0,不参与累加)。

最终ans=4,与题目示例输出一致,验证了代码的正确性。

时间复杂度

  • 遍历字符串一次,while循环是 "跳过连续0" 的优化,整体时间复杂度为O(n)n是字符串长度),非常高效。
相关推荐
夏鹏今天学习了吗5 小时前
【LeetCode热题100(82/100)】单词拆分
算法·leetcode·职场和发展
mit6.8246 小时前
mysql exe
算法
2501_901147836 小时前
动态规划在整除子集问题中的应用与高性能实现分析
算法·职场和发展·动态规划
中草药z7 小时前
【嵌入模型】概念、应用与两大 AI 开源社区(Hugging Face / 魔塔)
人工智能·算法·机器学习·数据集·向量·嵌入模型
CCPC不拿奖不改名7 小时前
SQL基础(SQL小白教程):MySQL语句+环境一键搭建+面试习题
数据库·sql·计算机网络·mysql·oracle·面试·职场和发展
踩坑记录7 小时前
leetcode hot100 189.轮转数组 medium
leetcode
知乎的哥廷根数学学派7 小时前
基于数据驱动的自适应正交小波基优化算法(Python)
开发语言·网络·人工智能·pytorch·python·深度学习·算法
ADI_OP7 小时前
ADAU1452的开发教程10:逻辑算法模块
算法·adi dsp中文资料·adi dsp·adi音频dsp·adi dsp开发教程·sigmadsp的开发详解
xingzhemengyou18 小时前
C语言 查找一个字符在字符串中第i次出现的位置
c语言·算法
Dream it possible!8 小时前
LeetCode 面试经典 150_二分查找_在排序数组中查找元素的第一个和最后一个位置(115_34_C++_中等)
c++·leetcode·面试