LeetCode 1529. 最少的后缀翻转次数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 1529. 最少的后缀翻转次数相关的知识,希望对你有一定的参考价值。


​1529. 最少的后缀翻转次数​

给你一个长度为 ​​n​​ 、下标从 0 开始的二进制字符串 ​​target​​​ 。你自己有另一个长度为 ​​n​​​ 的二进制字符串 ​​s​​​ ,最初每一位上都是 0 。你想要让 ​​s​​​ 和 ​​target​​ 相等。

在一步操作,你可以选择下标 ​​i​​​(​​0 <= i < n​​)并翻转在 闭区间​[i, n - 1]​​​ 内的所有位。翻转意味着 ​​0​​​ 变为 ​​1​​​ ,而 ​​1​​​ 变为 ​​0​​ 。

返回使 ​​s​​​ 与 ​​target​​ 相等需要的最少翻转次数。

示例 1:

输入:target = "10111"
输出:3
解释:最初,s = "00000" 。
选择下标 i = 2: "00000" -> "00111"
选择下标 i = 0: "00111" -> "11000"
选择下标 i = 1: "11000" -> "10111"
要达成目标,需要至少 3 次翻转。

示例 2:

输入:target = "101"
输出:3
解释:最初,s = "000" 。
选择下标 i = 0: "000" -> "111"
选择下标 i = 1: "111" -> "100"
选择下标 i = 2: "100" -> "101"
要达成目标,需要至少 3 次翻转。

示例 3:

输入:target = "00000"
输出:0
解释:由于 s 已经等于目标,所以不需要任何操作

提示:

  • ​n == target.length​
  • ​1 <= n <= 105​
  • ​target[i]​​​ 为 ​​0​​​ 或 ​​1​

二、方法一

贪心,由于如果前一个与当前一个不相同,肯定在i处发生过一次反转,就可以记录,遍历就可以得到

class Solution 
public int minFlips(String target)
int res = 0;
char pre = 0;
for (int i = 0; i < target.length(); i++)
char cur = target.charAt(i);
if (cur != pre)
res++;
pre = cur;


return res;

复杂度分析

  • 时间复杂度:O(n),其中 n 是字符串 target 的长度。遍历字符串一次。
  • 空间复杂度:O(1)。只需要维护常量的额外空间。


以上是关于LeetCode 1529. 最少的后缀翻转次数的主要内容,如果未能解决你的问题,请参考以下文章

算法leetcode每日一练2220. 转换数字的最少位翻转次数

LeetCode 1284. Minimum Number of Flips to Convert Binary Matrix to Zero Matrix (最少翻转次数将二进制矩阵全部置为0)(示

LeetCode 1611. 使整数变为 0 的最少操作次数

LeetCode Algorithm 995. K 连续位的最小翻转次数

LeetCode Algorithm 995. K 连续位的最小翻转次数

LeetCode 926. Flip String to Monotone Increasing (将字符串翻转到单调递增)