博客
关于我
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/

你可能感兴趣的文章
nodejs中Express 路由统一设置缓存的小技巧
查看>>
Nodejs中的fs模块的使用
查看>>
nodejs包管理工具对比:npm、Yarn、cnpm、npx
查看>>
NodeJs单元测试之 API性能测试
查看>>
nodejs图片转换字节保存
查看>>
nodejs字符与字节之间的转换
查看>>
NodeJs学习笔记001--npm换源
查看>>
NodeJs学习笔记002--npm常用命令详解
查看>>
nodejs学习笔记一——nodejs安装
查看>>
NodeJS实现跨域的方法( 4种 )
查看>>
nodejs封装http请求
查看>>
nodejs常用组件
查看>>
nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
查看>>
Nodejs异步回调的处理方法总结
查看>>
NodeJS报错 Fatal error: ENOSPC: System limit for number of file watchers reached, watch ‘...path...‘
查看>>
Nodejs教程09:实现一个带接口请求的简单服务器
查看>>
nodejs服务端实现post请求
查看>>
nodejs框架,原理,组件,核心,跟npm和vue的关系
查看>>
Nodejs模块、自定义模块、CommonJs的概念和使用
查看>>
nodejs生成多层目录和生成文件的通用方法
查看>>