当前位置: 首页 > news >正文

2025.11.13 力扣每日一题

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

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"为例)

字符串拆解为:1 → 00 → 11 → 0 → 1

  • 遇到第一个'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是字符串长度),非常高效。
http://www.dtcms.com/a/604890.html

相关文章:

  • “暗激子(dark excitons)” 以 30万倍亮度被观测到
  • 数据归一化:提升模型训练的关键技巧
  • 网站外链建设可以提升网站权重对吗三亚平台公司
  • 怎么做一种网站为别人宣传lamp 做网站
  • UE5制作扭曲声波效果
  • 从 OneThreadOneLoop 线程池到进程池:高性能 Reactor 服务器的演进
  • C语言在线编译环境 | 提高编程效率与学习体验
  • 矩阵起源成功登陆深圳“专精特新”专板,加速 AI 数据智能新进程!
  • MPC模型预测控制原理全解析:从状态预测、矩阵推导到QP求解与滚动优化(含完整手推过程)
  • android recyclerview缓存2_四级缓存机制
  • [特殊字符] 在 macOS 上设置 SQLite
  • android recyclerview缓存1_概念和常见问题
  • SQLite 速成学习
  • [特殊字符] 在 Windows 上设置 SQLite
  • 做资源网站违法吗深圳大梅沙
  • 【环境数据处理】-基于R批量对环境数据克里金插值提高数据精度
  • 广州wap网站建设百度seo优化技术
  • linux centos常用命令整理
  • Java设计模式之建造者模式(Builder)详解
  • [智能体设计模式] 第6章:规划
  • 学习react第三天
  • 营销软文网站西安网站建设网络公司熊掌号
  • 二分查找算法介绍及使用
  • [element-plus] el-tree 动态增加节点,删除节点
  • SQL:从数据基石到安全前线的双重审视
  • 数据结构:双向链表(1)
  • 【C++】深入拆解二叉搜索树:从递归与非递归双视角,彻底掌握STL容器的基石
  • 深圳趣网站建设网络外包服务公司
  • Axios 全面详解
  • ios-AVIF