每日一题-力扣-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. 累加所有操作的成本得到最终结果

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

相关推荐
亿牛云爬虫专家33 分钟前
Kubernetes下的分布式采集系统设计与实战:趋势监测失效引发的架构进化
分布式·python·架构·kubernetes·爬虫代理·监测·采集
董董灿是个攻城狮3 小时前
5分钟搞懂什么是窗口注意力?
算法
Dann Hiroaki3 小时前
笔记分享: 哈尔滨工业大学CS31002编译原理——02. 语法分析
笔记·算法
蹦蹦跳跳真可爱5895 小时前
Python----OpenCV(图像増强——高通滤波(索贝尔算子、沙尔算子、拉普拉斯算子),图像浮雕与特效处理)
人工智能·python·opencv·计算机视觉
nananaij5 小时前
【Python进阶篇 面向对象程序设计(3) 继承】
开发语言·python·神经网络·pycharm
雷羿 LexChien5 小时前
从 Prompt 管理到人格稳定:探索 Cursor AI 编辑器如何赋能 Prompt 工程与人格风格设计(上)
人工智能·python·llm·编辑器·prompt
qqxhb5 小时前
零基础数据结构与算法——第四章:基础算法-排序(上)
java·数据结构·算法·冒泡·插入·选择
敲键盘的小夜猫6 小时前
LLM复杂记忆存储-多会话隔离案例实战
人工智能·python·langchain
高压锅_12206 小时前
Django Channels WebSocket实时通信实战:从聊天功能到消息推送
python·websocket·django
FirstFrost --sy6 小时前
数据结构之二叉树
c语言·数据结构·c++·算法·链表·深度优先·广度优先