- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
N 轮 压缩在字符串上运行,其中每一轮用一个特殊字符(使用字典)替换一些字符模式。
给定这个压缩字符串和用于压缩的字典,我们需要找到原始字符串。
用于压缩的字典:
b12k -> ?
a?l -> #
#mn -> !
因此,字符串 ab12klmn 被压缩为 !
哪种数据结构最适合存储此字典,以便解压缩是 O(n) 操作,使用的额外空间最少?
我尝试过的:这是一个面试问题,我将字典存储在一个映射中,目标字母表(压缩字典的)作为我的映射的键,并将解压缩的字符串作为值。然后遍历给定的字符串,用它们各自的扩展替换特殊字符。例如:
! -> ab12klmn
# -> ab12k
? -> b12k
然后为了减少字符串模式的重复,我对这本字典做了树状结构,但面试官并不满意。我可以在哪里改进此解决方案?
最佳答案
我知道我们需要从给定的压缩字符串中取回原始字符串。
您可以在此处使用的最佳数据结构可以是二维向量(动态数组)。我将尝试解释为什么这是解决此问题的最佳数据结构。
但由于只有 256 个字符,我们将按如下方式存储字典。让我们有一个最多 256 行的二维字符串向量。对于这个例子
b12k -> ?
a?l -> #
#mn -> !
所以我们将把“b12k”存储在 v[63] 作为 '?' 的 ASCII 值是 63。类似地,我们将存储我们将在 v[35] 存储“a?l”,因为 '#' 的 ASCII 值是 35 等等,
现在如何找到原始字符串:
我们从压缩字符串开始。
初始化将存储最终答案的字符串。我们称它为 origString = ""。
开始遍历字符串。如果它是非特殊字符,则将此字符添加到 origString。
如果我们发现任何特殊字符,只需转到该字符的 ASCII 值及其在二维向量中的相应位置。
转到第 2 步。
伪代码是
origString = "";
func getOriginalFromCompressed(string s)
for i = [0:s.length()-1]
if(v[s[i]].length()) getOriginalFromCompressed(v[s[i]]);
else origString = stringConcat(origString,s[i]); //add the charcacter to your final ans
end for
end func
origString 具有原始字符串。
所以这个解的时间和空间复杂度是O(n)。其中 n = 给定字典中所有字符串的长度总和。
关于字符串解压 : Reduce time and space complexity,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57456698/
我系统上的docker info命令输出如下: # docker info Containers: 0 Images: 0 Storage Driver: devicemapper ..... D
我如何捕获用户按下 ctrl + space + space? 我用这段代码成功测试了ctrl + space: RegisterHotKey(0, 1, MOD_CONTROL, VK_SPACE)
我有一个 Matlab 图,我想在论文中使用。此图包含多个 cdfplots。现在的问题是我不能使用标记,因为在情节中变得非常密集。如果我想让样本稀疏,我必须从 cdfplot 中删除一些样本,这将导
我正在尝试获取我将用于备份的服务器上所有数据库的列表。以下是我尝试打印数据库列表但出现错误的代码片段。如何解决?添加双方括号并不能解决问题。 我已经研究了一些类似的问题,但我无法弄清楚。 grep:字
我了解 new gen/old gen/perm gen 之间的区别,但我不知道“To Space”和“From Space”是什么。我看到我的“From Space”使用率达到 99.8%,而“To
我当前有一个返回时看起来像这样的字符串: //This is the url string // the-great-debate---toilet-paper-over-or-under-the-r
我太亲密了。我正在尝试编写用于Notepad++的正则表达式表达式,以用空格替换破折号,而忽略已经用前置/后置空格代替的破折号。我知道我可以用“foobarfoo”搜索/替换“-”,然后搜索“-”替换
我的 ANTLR 代码如下: LPARENTHESIS : ('('); RPARENTHESIS : (')'); fragment CHARACTER : ('a'..'z'|'0'..'9'|)
在过去的 6 个小时里,我一直在尝试在我的 webgl 应用程序中实现点击,但我找不到任何关于这个主题的足够清晰的内容。 到目前为止,我想出的是伪代码: screenSpace = mousePosi
如何使用正则表达式来测试空格或制表符,但不测试换行符? 我尝试了 \s,但我发现它也测试换行符。 我使用C# (.NET) 和 WPF ,但这应该不重要。 最佳答案 使用字符类:[\t] 关于rege
我想解析以下内容: name:name 名称以字母开头和结尾,并且可以包含字母和空格的任意组合。它们也可以是空白的。我的规则是: identifier = alnum (space* alnum)*;
有什么办法可以让 Eden 空间按比例大于 Tenured 空间吗?有 NewRatio 但它以相反的方式工作(Tenured 比 Eden 大几倍)。 我知道有 -XX:NewSize= 和 -XX
我正在编写一个程序,让人们输入他们的信息(姓名,年龄......)。对于姓名输入,我不希望他们留空,只允许字母和空格,但不能以空格开头。合适的正则表达式是什么?我尝试使用: ^[a-zA-Z\\s]*
好的,我正在制作一个程序,它也可以制作垂直线、水平线和对角线!我对我的一个没有任何意义的输出感到困惑。 所以我的伪代码是这样的: //enter a char //enter a number
当我使用 scp 从服务器复制文件时, 我错误地使用了命令 scp xxx@xxxx:xx.zip . 当我完成后,我发现该文件的名称是 .我无法解压 这是目录列表。 http://pfil
我需要一个 bat 文件来获取 Windows 系统中 C:\驱动器的总空间和可用空间(以 GB(千兆字节)为单位),并创建一个包含详细信息的文本文件。 注意:我不想使用任何外部实用程序。 最佳答案
作为预处理我的数据的一部分。我希望能够替换空格后跟数字,同时保留空格后跟一个字符。例如: Input String: '8.1.7 Sep 2000 Dec 2004 Dec 2006 Indefin
我正在编写一个 XPath 表达式,但我修复了一个奇怪的错误,但是以下两个 XPath 表达式之间有什么区别? "//td[starts-with(normalize-space()),'Posted
在 C 中,当读取文本文件时,是否有可能接受一个未知大小的整数值(假设它适合 int),因为它在数字之前和数字之后都有一个空格。例如。 363 865我想分别存储 363 和 865,因为它们有自己的
在 sys/ptrace.h 中,我看到类似这样的内容: @define PT_READ_I 1 /* read world in child's I space*/ @define PT_READ
我是一名优秀的程序员,十分优秀!