Swift|Swift 的字符串前后缀匹配
同步:ckitakishi.com
之前修改了项目中一个 increment search 的组件,最近刚好又看到下题,于是想说一说前后缀匹配的事儿~
【Swift|Swift 的字符串前后缀匹配】14. Longest Common Prefix
这是一个给定字符串数组,求所有字符串最长公有前缀的问题。
直接用 O(1)
的额外空间来存储一个最长公有前缀,一次遍历后返回前缀字符串。这个想法自然到不需要多加解释,然而这么一写竟然击败了 100% 的 Swift 提交结果...
所以不得不提一下十分高效的 hasPrefix(_:)
方法,它接受一个 String
类型的参数并返回 Bool
值,这里字符串大小写敏感,且基于 Unicode 标准等价。此外,与之对应用于比较后缀字符串的方法是 hasSuffix(_:)
。
// Unicode 标准等价
let composedCafe = "Café"
let decomposedCafe = "Cafe\u{0301}"
print(cafe.hasPrefix(composedCafe))
// Prints "true"
print(cafe.hasPrefix(decomposedCafe))
// Prints "true"
Source Code
推荐阅读
- 热闹中的孤独
- JAVA(抽象类与接口的区别&重载与重写&内存泄漏)
- 放屁有这三个特征的,请注意啦!这说明你的身体毒素太多
- 一个人的旅行,三亚
- 布丽吉特,人生绝对的赢家
- 慢慢的美丽
- 尽力
- 一个小故事,我的思考。
- 家乡的那条小河
- 《真与假的困惑》???|《真与假的困惑》??? ——致良知是一种伟大的力量