博客
关于我
LeetCode0844. 比较含退格的字符串
阅读量:304 次
发布时间:2019-03-03

本文共 690 字,大约阅读时间需要 2 分钟。

一. 题目

判断两个字符串是否是同一个回文串,但字符串中可以包含特殊字符'#',特殊字符'#'的作用是可以清空前面的所有字符。例如,字符串"ab#c"可以转换为"ab",而"abc#def"则会转换为"def"。

示例:

- 字符串S = "abc#def" - 字符串T = "abc#def" - 结果应该是True,因为两个字符串在去除'#'后的结果相同。
二. 方法一: 无脑暴力法

通过逐个遍历两个字符串中的每个字符,分别构建两个结果字符串。遇到'#'时,截断当前结果字符串的最后一个字符。如果遇到其他字符,则直接追加到结果字符串中。最后比较两个结果字符串是否相同。

解题代码:

```pythondef backspaceCompare(self, S: str, T: str) -> bool: str1 = "" str2 = "" for ele in S: if ele != "#": str1 += ele else: str1 = str1[:-1] for ele in T: if ele != "#": str2 += ele else: str2 = str2[:-1] return str1 == str2```

分析:

- 该方法通过两次遍历字符串,分别处理每个字符,时间复杂度为O(n),其中n是字符串的长度。 - 在遇到'#'时,截断字符串的最后一个字符,这一步操作的时间复杂度为O(k),其中k是截断前的字符数量。因此,在最坏情况下,时间复杂度可能会接近O(n^2)。 - 该方法简单易懂,但在处理大量特殊字符时可能会导致性能问题。

转载地址:http://ysum.baihongyu.com/

你可能感兴趣的文章
Objective-C实现adaboost算法(附完整源码)
查看>>
Objective-C实现Adler32算法(附完整源码)
查看>>
Objective-C实现AES算法(附完整源码)
查看>>
Objective-C实现AffineCipher仿射密码算法(附完整源码)
查看>>
Objective-C实现aliquot sum等分求和算法(附完整源码)
查看>>
Objective-C实现all combinations所有组合算法(附完整源码)
查看>>
Objective-C实现all permutations所有排列算法(附完整源码)
查看>>
Objective-C实现all subsequences所有子序列算法(附完整源码)
查看>>
Objective-C实现AlphaNumericalSort字母数字排序算法(附完整源码)
查看>>
Objective-C实现alternate disjoint set不相交集算法(附完整源码)
查看>>
Objective-C实现alternative list arrange备选列表排列算法(附完整源码)
查看>>
Objective-C实现An Armstrong number阿姆斯特朗数算法(附完整源码)
查看>>
Objective-C实现anagrams字谜算法(附完整源码)
查看>>
Objective-C实现ApproximationMonteCarlo蒙特卡洛方法计算pi值算法 (附完整源码)
查看>>
Objective-C实现area under curve曲线下面积算法(附完整源码)
查看>>
Objective-C实现arithmetic算术算法(附完整源码)
查看>>
Objective-C实现armstrong numbers阿姆斯壮数算法(附完整源码)
查看>>
Objective-C实现articulation-points(关键点)(割点)算法(附完整源码)
查看>>
Objective-C实现atoi函数功能(附完整源码)
查看>>
Objective-C实现average absolute deviation平均绝对偏差算法(附完整源码)
查看>>