每日算法系列【LeetCode 926】将字符串翻转到单调递增

简介: 如果一个由 '0' 和 '1' 组成的字符串,是以一些 '0'(可能没有 '0')后面跟着一些 '1'(也可能没有 '1')的形式组成的,那么该字符串是单调递增的。我们给出一个由字符 '0' 和 '1' 组成的字符串 S,我们可以将任何 '0' 翻转为 '1' 或者将 '1' 翻转为 '0'。返回使 S 单调递增的最小翻转次数。

题目描述


如果一个由 '0' 和 '1' 组成的字符串,是以一些 '0'(可能没有 '0')后面跟着一些 '1'(也可能没有 '1')的形式组成的,那么该字符串是单调递增的。

我们给出一个由字符 '0' 和 '1' 组成的字符串 S,我们可以将任何 '0' 翻转为 '1' 或者将 '1' 翻转为 '0'。

返回使 S 单调递增的最小翻转次数。

示例1

输入:
"00110
"输出:
1
解释:
我们翻转最后一位得到 00111.

示例2

输入:
"010110"
输出:
2
解释:
我们翻转得到 011111,或者是 000111。

示例3

输入:
"00011000"
输出:
2
解释:
我们翻转得到 00000000。

提示

  • 1 <= S.length <= 20000
  • S 中只包含字符 '0' 和 '1'

题解


要想把字符串变成递增的,只有两种可能,一种就是从某一处开始全是 1 ,之前都是 0 或者没有,另一种就是全 0 。那么我们只需要遍历这个 1 开始的位置就行了。

对于位置 i ,我们假设从它开始后面都是 1 ,前面都是 0 ,那么需要修改的的次数就是它后面 0 的数量减去它前面 1 的数量。


image.png

代码


c++

classSolution {
public:   
intminFlipsMonoIncr(stringS) {    
intn=S.size(); 
intdp[n+1];   
dp[n] =0;     
for (inti=n-1; i>=0; --i) {    
dp[i] =dp[i+1] + (S[i] =='1'); 
        }  
intres=dp[0]; 
for (inti=0; i<n; ++i) {    
res=min(res, dp[0]-dp[i]+n-i-dp[i]);   
        }    
returnres;
    }
};

python

classSolution:  
defminFlipsMonoIncr(self, S: str) ->int:   
n=len(S)    
dp= [0] * (n+1)    
foriinrange(n-1, -1, -1): 
dp[i] =dp[i+1] + (1ifS[i]=='1'else0)   
res=dp[0]     
foriinrange(n):   
res=min(res, dp[0]-dp[i]+n-i-dp[i])  
returnres

image.png

作者简介:godweiyang知乎同名华东师范大学计算机系硕士在读,方向自然语言处理与深度学习喜欢与人分享技术与知识,期待与你的进一步交流~


相关文章
|
机器学习/深度学习 计算机视觉 Python
图像数据的特征提取与预处理方法,涵盖图像数据的特点、主要的特征提取技术
本文深入探讨了图像数据的特征提取与预处理方法,涵盖图像数据的特点、主要的特征提取技术(如颜色、纹理、形状特征)及预处理步骤(如图像增强、去噪、分割)。同时介绍了Python中常用的OpenCV和Scikit-image库,并提供了代码示例,强调了预处理的重要性及其在提升模型性能中的作用。
1909 5
|
机器学习/深度学习 算法
全连接层那些事(Fully Connected Layer)
全连接层那些事(Fully Connected Layer)
|
算法 C++ Python
每日算法系列【LeetCode 926】将字符串翻转到单调递增
每日算法系列【LeetCode 926】将字符串翻转到单调递增
206 0
|
1天前
|
数据采集 人工智能 安全
|
10天前
|
云安全 监控 安全
|
2天前
|
自然语言处理 API
万相 Wan2.6 全新升级发布!人人都能当导演的时代来了
通义万相2.6全新升级,支持文生图、图生视频、文生视频,打造电影级创作体验。智能分镜、角色扮演、音画同步,让创意一键成片,大众也能轻松制作高质量短视频。
879 150
|
15天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1615 8
|
6天前
|
人工智能 前端开发 文件存储
星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择
星哥带你玩转飞牛NAS,部署开源笔记TriliumNext!支持树状知识库、多端同步、AI摘要与代码高亮,数据自主可控,打造个人“第二大脑”。高效玩家的新选择,轻松搭建专属知识管理体系。
361 152
|
7天前
|
人工智能 自然语言处理 API
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸
一句话生成拓扑图!next-ai-draw-io 结合 AI 与 Draw.io,通过自然语言秒出架构图,支持私有部署、免费大模型接口,彻底解放生产力,绘图效率直接爆炸。
585 152