iOS LeetCode ☞ 从英文中重建数字

iOS LeetCode ☞ 从英文中重建数字,第1张

给你一个字符串 s ,其中包含字母顺序打乱的用英文单词表示的若干数字(0-9)。按 升序 返回原始的数字。

示例 1:

输入:s = "owoztneoer"
输出:"012"

示例 2:

输入:s = "fviefuro"
输出:"45"

提示:

1 <= s.length <= 105s[i]["e","g","f","i","h","o","n","s","r","u","t","w","v","x","z"] 这些字符之一s 保证是一个符合题目要求的字符串 解题思路

首先我们可以统计每个字母分别在哪些数字中出现:

字母数字
e0 1 3 5 7 8 9
f4 5
g8
h3 8
i5 6 8 9
n1 7 9
o0 1 2 4
r0 3 4
s6 7
t2 3 8
u4
v5 7
w2
x6
z0

可以发现,z, w, u, x, g 都只在一个数字中,即 0, 2, 4, 6, 8 中出现。因此我们可以使用一个哈希表统计每个字母出现的次数,那么 z, w, u, x, g 出现的次数,即分别为 0, 2, 4, 6, 8 出现的次数。

随后我们可以注意那些只在两个数字中出现的字符:

h 只在 3, 8 中出现。由于我们已经知道了 8 出现的次数,因此可以计算出 3 出现的次数。

f 只在 4, 5 中出现。由于我们已经知道了 4 出现的次数,因此可以计算出 5 出现的次数。

s 只在 6, 7 中出现。由于我们已经知道了 6 出现的次数,因此可以计算出 7 出现的次数。

此时,我们还剩下 1 和 9 的出现次数没有求出:

o 只在 0, 1, 2, 4 中出现,由于我们已经知道了 0, 2, 4 出现的次数,因此可以计算出 1 出现的次数。

最后的 9 就可以通过 n, i, e 中的任一字符计算得到了。这里推荐使用 i 进行计算,因为 n 在 9 中出现了 2 次,e 在 3 中出现了 2 次,容易在计算中遗漏。

当我们统计完每个数字出现的次数后,我们按照升序将它们进行拼接即可。

代码
	// 423. 从英文中重建数字
    func originalDigits(_ s: String) -> String {
        var c = [Character: Int]()
        for char in s {
            c[char, default: 0] += 1
        }
        
        var cnt = [Int](repeating: 0, count: 10)
        cnt[0] = c["z"] ?? 0
        cnt[2] = c["w"] ?? 0
        cnt[4] = c["u"] ?? 0
        cnt[6] = c["x"] ?? 0
        cnt[8] = c["g"] ?? 0
        cnt[3] = (c["h"] ?? 0) - cnt[8]
        cnt[5] = (c["f"] ?? 0) - cnt[4]
        cnt[7] = (c["s"] ?? 0) - cnt[6]
        cnt[1] = (c["o"] ?? 0) - cnt[0] - cnt[2] - cnt[4]
        cnt[9] = (c["i"] ?? 0) - cnt[5] - cnt[6] - cnt[8]
        
        var ans = ""
        for i in 0..<10 {
            for _ in 0..<cnt[i] {
                ans.append("\(i)")
            }
        }
        return ans
    }

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/994475.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存