每日一题-力扣-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: s0=0, s1=1,不相等,选择 min(0+1, 6-0-1) = min(1, 5) = 1,累计成本 = 1
    • i=1: s1=1, s2=0,不相等,选择 min(1+1, 6-1-1) = min(2, 4) = 2,累计成本 = 1+2 = 3
    • i=2: s2=0, s3=1,不相等,选择 min(2+1, 6-2-1) = min(3, 3) = 3,累计成本 = 3+3 = 6
    • i=3: s3=1, s4=0,不相等,选择 min(3+1, 6-3-1) = min(4, 2) = 2,累计成本 = 6+2 = 8
    • i=4: s4=0, s5=1,不相等,选择 min(4+1, 6-4-1) = min(5, 1) = 1,累计成本 = 8+1 = 9
  3. 最终结果是 9

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

总结

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

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

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

相关推荐
阿正的梦工坊14 分钟前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
Zella折耳根18 分钟前
复习篇-继承和接口
java·开发语言·python
诗词在线22 分钟前
求推荐飞花令
大数据·人工智能·python
yijianace36 分钟前
Python线程与多线程完全总结(从入门到理解并发本质)
开发语言·python
八解毒剂2 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
会Tk矩阵群控的小木2 小时前
基于Python的iMessage短信群发与社媒多账号统一管理系统实现
开发语言·windows·python·新媒体运营·开源软件·个人开发
运行时记录2 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
质造者2 小时前
LangChain + Ollama + Tavily 实现旅游问答系统
linux·人工智能·python·langchain·rag
啦啦啦啦啦zzzz2 小时前
算法总结(二分查找、双指针)
c++·算法
伊布拉西莫2 小时前
【流畅的Python】第20章:并发执行器 — 学习笔记
笔记·python·学习