LeetCode - #87 扰乱字符串

在这里插入图片描述

在这里插入图片描述

前言

本题由于没有合适答案为以往遗留问题,最近有时间将以往遗留问题一一完善。

我们社区陆续会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 职业健身教练。)的 Swift 算法题题解整理为文字版以方便大家学习与阅读。

LeetCode 算法到目前我们已经更新到 86 期,我们会保持更新时间和进度(周一、周三、周五早上 9:00 发布),每期的内容不多,我们希望大家可以在上班路上阅读,长久积累会有很大提升。

不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。如果大家有建议和意见欢迎在文末留言,我们会尽力满足大家的需求。

难度水平:困难

1. 描述

使用下面描述的算法可以扰乱字符串 s 得到字符串 t

  1. 如果字符串的长度为 1 ,算法停止
  2. 如果字符串的长度 > 1 ,执行下述步骤:
    • 在一个随机下标处将字符串分割成两个非空的子字符串。即,如果已知字符串 s ,则可以将其分成两个子字符串 xy ,且满足 s = x + y
    • 随机 决定是要「交换两个子字符串」还是要「保持这两个子字符串的顺序不变」。即,在执行这一步骤之后,s 可能是 s = x + y 或者 s = y + x
    • xy 这两个子字符串上继续从步骤 1 开始递归执行此算法。

给你两个 长度相等 的字符串 s1s2,判断 s2 是否是 s1 的扰乱字符串。如果是,返回 true ;否则,返回 false

2. 示例

示例 1

输入:s1 = "great", s2 = "rgeat"
输出:true
解释:s1 上可能发生的一种情形是:
"great" --> "gr/eat" // 在一个随机下标处分割得到两个子字符串
"gr/eat" --> "gr/eat" // 随机决定:「保持这两个子字符串的顺序不变」
"gr/eat" --> "g/r / e/at" // 在子字符串上递归执行此算法。两个子字符串分别在随机下标处进行一轮分割
"g/r / e/at" --> "r/g / e/at" // 随机决定:第一组「交换两个子字符串」,第二组「保持这两个子字符串的顺序不变」
"r/g / e/at" --> "r/g / e/ a/t" // 继续递归执行此算法,将 "at" 分割得到 "a/t"
"r/g / e/ a/t" --> "r/g / e/ a/t" // 随机决定:「保持这两个子字符串的顺序不变」
算法终止,结果字符串和 s2 相同,都是 "rgeat"
这是一种能够扰乱 s1 得到 s2 的情形,可以认为 s2 是 s1 的扰乱字符串,返回 true

示例 2

输入:s1 = "abcde", s2 = "caebd"
输出:false

示例 3

输入:s1 = "a", s2 = "a"
输出:true

提示:

  • s1.length == s2.length
  • 1 <= s1.length <= 30
  • s1s2 由小写英文字母组成

3. 答案

题解 1

class Solution {
   
   func isScramble(_ s1: String, _ s2: String) -> Bool {
   
       if s1 == s2 {
   
           return true
       }

       var letters = [Int](repeating: 0, count: 26)

       for i in 0..<s1.count {
   
           let aASCII = Character("a").ascii
           letters[s1[i].ascii - aASCII] += 1
           letters[s2[i].ascii - aASCII] -= 1
       }
       for i in 0..<26 {
   
           if letters[i] != 0 {
   
               return false
           }
       }
       for i in 1..<s1.count {
   
           if isScramble(s1[0..<i], s2[0..<i]) &&
               isScramble(s1[i..<s1.count], s2[i..<s2.count]) {
   
               return true
           }
           if isScramble(s1[0..<i], s2[(s2.count - i)..<s2.count]) &&
               isScramble(s1[i..<s1.count], s2[0..<(s2.count - i)]) {
   
               return true
           }
       }

       return false
   }
}

extension String {
   
   subscript (i: Int) -> Character {
   
       return self[index(startIndex, offsetBy: i)]
   }

   subscript(_ range: CountableRange<Int>) -> String {
   
       let idx1 = index(startIndex, offsetBy: max(0, range.lowerBound))
       let idx2 = index(startIndex, offsetBy: min(self.count, range.upperBound))
       return String(self[idx1..<idx2])
   }
}

extension Character {
   
   var ascii: Int {
   
       get {
   
           let s = String(self).unicodeScalars
           return Int(s[s.startIndex].value)
       }
   }

   func isDigit() -> Bool {
   
       return self >= "0" && self <= "9"
   }
}

点击前往 LeetCode 练习

关于我们

我们是由 Swift 爱好者共同维护,我们会分享以 Swift 实战、SwiftUI、Swift 基础为核心的技术内容,也整理收集优秀的学习资料。

相关推荐

  1. 力扣0087——扰乱字符串

    2023-12-06 16:02:01       37 阅读
  2. LeetCode //C - 87. Scramble String

    2023-12-06 16:02:01       9 阅读
  3. leetcode 字符串

    2023-12-06 16:02:01       7 阅读
  4. 面试算法-80-字符串相乘

    2023-12-06 16:02:01       16 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-06 16:02:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-06 16:02:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-06 16:02:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-06 16:02:01       20 阅读

热门阅读

  1. P5706 【深基2.例8】再分肥宅水

    2023-12-06 16:02:01       44 阅读
  2. AIOps、微服务和云平台

    2023-12-06 16:02:01       36 阅读
  3. 做题笔记:SQL Sever 方式做牛客SQL的题目--VQ29

    2023-12-06 16:02:01       34 阅读
  4. 蓝桥杯官网练习题(平均)

    2023-12-06 16:02:01       40 阅读
  5. vscode配置代码片段

    2023-12-06 16:02:01       35 阅读
  6. rocketmq 集群环境部署及与spring cloud 集成

    2023-12-06 16:02:01       30 阅读
  7. RepidJson将内容写入文件简单代码示例

    2023-12-06 16:02:01       35 阅读
  8. 深度学习中的Transformer机制

    2023-12-06 16:02:01       37 阅读
  9. 封装请求头内容格式

    2023-12-06 16:02:01       37 阅读
  10. Flink-时间窗口

    2023-12-06 16:02:01       49 阅读
  11. AGI = 大模型 + 知识图谱 + 强化学习

    2023-12-06 16:02:01       42 阅读
  12. 数据库事务

    2023-12-06 16:02:01       35 阅读