3223。运算后字符串的最小长度
难度:中等
主题: 哈希表、字符串、计数
给你一个字符串 s。
您可以对任意次执行以下过程:
- 在字符串中选择一个索引 i,使得索引 i 左侧至少有 一个字符等于 s[i],并且 至少 一个字符右边也等于 s[i]. 删除索引 i 的
- 左边 等于 s[i] 的 最接近的 字符。 删除索引 i 的
- 右边 等于 s[i] 的 最接近的 字符。
可以达到的最终字符串s的最小长度。
示例1:
- 输入: s = "abaacbcbb"
- 输出: 5
- 说明:我们执行以下操作:
- 选择索引 2,然后删除索引 0 和 3 处的字符。生成的字符串为 s = "bacbcbb"。
- 选择索引 3,然后删除索引 0 和 5 处的字符。生成的字符串为 s = "acbcb"。
示例2:
- 输入: s = "aa"
- 输出: 2
- 解释:我们无法执行任何操作,因此我们返回原始字符串的长度。
约束:
- 1 5
s 仅由小写英文字母组成。
提示:
- 只有每个字符出现的频率对于找到最终答案很重要。
- 如果某个字符出现次数少于 3 次,我们无法对其执行任何处理。
- 假设有一个字符在字符串中出现至少3次,我们可以重复删除其中两个字符,直到最多出现2次。
解决方案:
我们需要关注字符串中每个字符的出现频率。解决方法如下:方法:
-
计算字符频率:
- 使用频率表来统计每个字符在字符串中出现的次数。
-
减少频率>= 3的字符:
- 如果一个字符出现3次或以上,我们可以重复删除其中两个,直到只剩下2次。
-
计算最小长度:
- 减少频率后,将所有字符的剩余数量相加。
让我们用 PHP 实现这个解决方案:3223。运算后字符串的最小长度
<?php /** * @param String $s * @return Integer */ function minimumLength($s) { ... ... ... /** * go to ./solution.php */ } // Example 1 $s1 = "abaacbcbb"; echo "Input: $s1\n"; echo "Output: " . minimumLength($s1) . "\n"; // Example 2 $s2 = "aa"; echo "Input: $s2\n"; echo "Output: " . minimumLength($s2) . "\n"; ?>
解释:
-
频率计数:
- 迭代字符串,并为每个字符增加 $Frequency 数组中的计数。
-
减少字符:
- 对于 $Frequency 数组中的每个字符,检查其计数是否为 3 或更多。如果是这样,请将其减少到最多 2。
-
计算结果:
- 对 $Frequency 数组中的值求和以获得字符串的最小可能长度。
演练示例:
示例1:
- 输入:s = "abaacbcbb"
- 频率:['a' => 3、'b'=> 4、'c' => 2]
- 减少后:
- '一' => 2(从 3 减少),
- 'b'=> 2(从 4 减少),
- 'c'=> 2(无需减少)。
- 最小长度:2 2 2 = 6。
示例2:
- 输入:s = "aa"
- 频率:['a' => 2]
- 不需要减少,因为没有字符的频率为 3 或更多。
- 最小长度:2。
复杂:
-
时间复杂度:
- 计数频率:O(n),其中 n 是字符串的长度。
- 减少:O(1)(恒定时间,因为只有 26 个小写字母)。
- 求和频率:O(1).
- 总体:O(n)。
-
空间复杂度:
- O(1),因为频率数组最多有 26 个条目。
这个解决方案非常高效,并且在问题的限制范围内运行良好。
联系链接
如果您发现本系列有帮助,请考虑在 GitHub 上给 存储库 一个星号或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!
如果您想要更多类似的有用内容,请随时关注我:
- 领英
- GitHub
以上是运算后字符串的最小长度的详细内容。更多信息请关注PHP中文网其他相关文章!

长URL(通常用关键字和跟踪参数都混乱)可以阻止访问者。 URL缩短脚本提供了解决方案,创建了简洁的链接,非常适合社交媒体和其他平台。 这些脚本对于单个网站很有价值

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

这是有关用Laravel后端构建React应用程序的系列的第二个也是最后一部分。在该系列的第一部分中,我们使用Laravel为基本的产品上市应用程序创建了一个RESTFUL API。在本教程中,我们将成为开发人员

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

2025年的PHP景观调查调查了当前的PHP发展趋势。 它探讨了框架用法,部署方法和挑战,旨在为开发人员和企业提供见解。 该调查预计现代PHP Versio的增长

在本文中,我们将在Laravel Web框架中探索通知系统。 Laravel中的通知系统使您可以通过不同渠道向用户发送通知。今天,我们将讨论您如何发送通知OV


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3汉化版
中文版,非常好用

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 Linux新版
SublimeText3 Linux最新版

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。