每日一题-力扣-2712: 使所有字符相等的最小成本 0327

LeetCode 2712: 使所有字符相等的最小成本 - 贪心算法解析

问题描述

一个二进制字符串 s,需要通过一系列操作使字符串中的所有字符相等(全为 '0' 或全为 '1')。可执行的操作有:

  1. 选择一个下标 i,反转从下标 0 到下标 i 的所有字符(包括下标 0 和 i),成本为 i + 1
  2. 选择一个下标 i,反转从下标 i 到下标 n - 1 的所有字符(包括下标 in - 1),成本为 n - i

需要计算使所有字符相等所需的最小成本。

贪心算法思路

本题可以使用贪心算法高效求解。关键洞察是:对于字符串中每一对相邻但不相等的字符,必须执行一次操作使它们相等

贪心策略分析

考虑字符串中的每一对相邻字符 s[i]s[i+1](其中 i 从 0 到 n-2):

  1. 如果 s[i] == s[i+1],这对字符已经相等,不需要操作
  2. 如果 s[i] != s[i+1],必须执行一次操作使它们相等。有两种选择:
    • 反转前缀 [0...i]:成本为 i + 1
    • 反转后缀 [i+1...n-1]:成本为 n - (i+1) = n - i - 1

贪心选择是:选择成本较小的那个操作 ,即 min(i + 1, n - i - 1)

为什么贪心算法有效?

可能会有疑问:前面的操作会影响后面的字符,为什么简单地对每个不同的相邻字符对独立做决策是正确的?

关键在于理解:

  • 每次操作只会影响连续的一段子串中的字符
  • 对于每对相邻不同的字符,必须通过某种方式使它们相等
  • 无论选择反转前缀还是后缀,最终目标都是使所有字符相等
  • 贪心策略确保了每次都选择成本最小的操作

局部最优的选择在这个问题中确实能导致全局最优解,因为:

  1. 每对相邻但不同的字符都至少需要一次操作
  2. 的操作不会创造新的不同相邻字符对
  3. 即使前面的操作改变了后面的字符,仍然只关心相邻字符是否相同

代码实现

python 复制代码
class Solution:
    def minimumCost(self, s: str) -> int:
        n = len(s)
        total_cost = 0
        
        for i in range(n-1):
            if s[i] != s[i+1]:
                # 选择反转前缀或后缀的最小成本
                total_cost += min(i+1, n-i-1)
        
        return total_cost

复杂度分析

  • 时间复杂度:O(n),只需要遍历字符串一次,对每对相邻字符做一次简单比较和计算。
  • 空间复杂度:O(1),只使用了几个变量,不随输入规模增长。

示例详解

通过一个例子来理解算法的执行过程。以输入 s = "010101" 为例:

  1. 长度 n = 6
  2. 遍历字符串的相邻字符对:
    • i=0: s[0]=0, s[1]=1,不相等,选择 min(0+1, 6-0-1) = min(1, 5) = 1,累计成本 = 1
    • i=1: s[1]=1, s[2]=0,不相等,选择 min(1+1, 6-1-1) = min(2, 4) = 2,累计成本 = 1+2 = 3
    • i=2: s[2]=0, s[3]=1,不相等,选择 min(2+1, 6-2-1) = min(3, 3) = 3,累计成本 = 3+3 = 6
    • i=3: s[3]=1, s[4]=0,不相等,选择 min(3+1, 6-3-1) = min(4, 2) = 2,累计成本 = 6+2 = 8
    • i=4: s[4]=0, s[5]=1,不相等,选择 min(4+1, 6-4-1) = min(5, 1) = 1,累计成本 = 8+1 = 9
  3. 最终结果是 9

这与示例中给出的期望输出相符。

总结

贪心算法是解决这个问题的最佳方法:

  1. 遍历字符串中的每对相邻字符
  2. 对于不相等的相邻字符对,选择成本最小的操作(反转前缀或后缀)
  3. 累加所有操作的成本得到最终结果

这个解法的关键在于识别出局部最优选择在这个问题中能够导致全局最优解。贪心策略在这里非常有效,因为操作不会增加新的不同相邻字符对的数量,而且每一对不同的相邻字符对都至少需要一次操作来解决。

相关推荐
__淡墨青衫__9 分钟前
Django之旅:第六节--mysql数据库操作增删改查(二)
后端·python·django
无影无踪的青蛙11 分钟前
[Python] 贪心算法简单版
开发语言·python·贪心算法
电科_银尘26 分钟前
【Matlab】-- 基于MATLAB的飞蛾扑火算法与反向传播算法的混凝土强度预测
开发语言·算法·matlab
aiweker28 分钟前
Python PDF解析利器:pdfplumber | AI应用开发
python·pdf
Fuction.28 分钟前
聚类注意点
人工智能·python·机器学习·kmeans·聚类
弈风千秋万古愁41 分钟前
python 语法篇(一)
数据库·python·mysql
wen__xvn1 小时前
Codeforces Round 1014 (Div. 2)2092A - Kamilka and the Sheep c++
开发语言·c++·算法
moz与京1 小时前
【附JS、Python、C++题解】Leetcode面试150题(12)多数问题
javascript·python·leetcode
向阳12181 小时前
doris:备份
后端·python·flask·doris
春风又。1 小时前
接口自动化——初识pytest
python·测试工具·自动化·pytest