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是字符串长度),非常高效。
相关推荐
LYFlied12 小时前
【每日算法】LeetCode 64. 最小路径和(多维动态规划)
数据结构·算法·leetcode·动态规划
七禾页丫12 小时前
面试记录12 软件(c++)工程师
c++·面试·职场和发展
Salt_072812 小时前
DAY44 简单 CNN
python·深度学习·神经网络·算法·机器学习·计算机视觉·cnn
货拉拉技术12 小时前
AI拍货选车,开启拉货新体验
算法
MobotStone12 小时前
一夜蒸发1000亿美元后,Google用什么夺回AI王座
算法
Wang2012201312 小时前
RNN和LSTM对比
人工智能·算法·架构
xueyongfu13 小时前
从Diffusion到VLA pi0(π0)
人工智能·算法·stable diffusion
永远睡不够的入13 小时前
快排(非递归)和归并的实现
数据结构·算法·深度优先
cheems952713 小时前
二叉树深搜算法练习(一)
数据结构·算法
sin_hielo13 小时前
leetcode 3074
数据结构·算法·leetcode