Go Java算法之从英文中重建数字示例详解
作者:黄丫丫
这篇文章主要为大家介绍了Go Java算法之从英文中重建数字示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
从英文中重建数字
给你一个字符串 s ,其中包含字母顺序打乱的用英文单词表示的若干数字(0-9)。按 升序 返回原始的数字。
示例 1:
输入:s = "owoztneoer" 输出:"012" 示例 2:
输入:s = "fviefuro" 输出:"45"
提示:
1 <= s.length <= 105
s[i] 为 ["e","g","f","i","h","o","n","s","r","u","t","w","v","x","z"] 这些字符之一
s 保证是一个符合题目要求的字符串
Java实现
先对 s 进行词频统计,然后根据「英文单词中的字符唯一性」确定构建的顺序,最后再对答案进行排序即可。
- zero 中的 z 在其余所有单词中都没出现过,可以先统计 zero 的出现次数,并构建 00;然后观察剩余数字,其中 eight 中的 g 具有唯一性,构建 88;
- 再发现 six 中的 x 具有唯一性,构建 66;
- 发现 three 中的 h 具有唯一性(利用在此之前 eight 已经被删除干净,词频中仅存在 three 对应的 h),构建 33 ...
最终可以确定一个可行的构建序列为 0, 8, 6, 3, 2, 7, 5, 9, 4, 1。
class Solution { static String[] ss = new String[]{"zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine"}; static int[] priority = new int[]{0, 8, 6, 3, 2, 7, 5, 9, 4, 1}; public String originalDigits(String s) { int n = s.length(); int[] cnts = new int[26]; for (int i = 0; i < n; i++) cnts[s.charAt(i) - 'a']++; StringBuilder sb = new StringBuilder(); for (int i : priority) { int k = Integer.MAX_VALUE; for (char c : ss[i].toCharArray()) k = Math.min(k, cnts[c - 'a']); for (char c : ss[i].toCharArray()) cnts[c - 'a'] -= k; while (k-- > 0) sb.append(i); } char[] cs = sb.toString().toCharArray(); Arrays.sort(cs); return String.valueOf(cs); } }
时间复杂度:O(mlogm)
空间复杂度:O(L+m)
Go实现
输入中各个字母的个数,可以知道一些数字的个数了,比如只有零用了z,只有六用了x等等,
在将一些可以求得的个数求了后,将它们占用的其他字母的个数排除掉,经过排除后,剩下的有用到别人用过的字母的数字的个数也可以得到了。 比如在四的个数通过u得到后,五的个数就可以通过剩下的f的个数得到了。
func originalDigits(s string) string { cnts, a := make([]int, 26), byte('a') for i := range s { cnts[s[i] - a]++ } zeros, twos, fours, sixs, eights := cnts[byte('z') - a], cnts[byte('w') - a], cnts[byte('u') - a], cnts[byte('x') - a], cnts[byte('g') - a] fives, sevens, ones, threes := cnts[byte('f') - a] - fours, cnts[byte('s') - a] - sixs, cnts[byte('o') - a] - zeros - twos - fours, cnts[byte('h') - a] - eights nines := cnts[byte('i') - a] - fives - sixs - eights return strings.Repeat("0", zeros) + strings.Repeat("1", ones) + strings.Repeat("2", twos) + strings.Repeat("3", threes) + strings.Repeat("4", fours) + strings.Repeat("5", fives) + strings.Repeat("6", sixs) + strings.Repeat("7", sevens) + strings.Repeat("8", eights) + strings.Repeat("9", nines) }
时间复杂度:O(mlogm)
空间复杂度:O(L+m)
以上就是Go Java算法之从英文中重建数字示例详解的详细内容,更多关于Go Java算法英文重建数字的资料请关注脚本之家其它相关文章!