题目大意:
上升下降字符串
给你一个字符串 s
,请你根据下面的算法重新构造字符串:
- 从 s 中选出 最小 的字符,将它 接在 结果字符串的后面。
- 从 s 剩余字符中选出 最小 的字符,且该字符比上一个添加的字符大,将它 接在 结果字符串后面。
- 重复步骤 2 ,直到你没法从 s 中选择字符。
- 从 s 中选出 最大 的字符,将它 接在 结果字符串的后面。
- 从 s 剩余字符中选出 最大 的字符,且该字符比上一个添加的字符小,将它 接在 结果字符串后面。
- 重复步骤 5 ,直到你没法从 s 中选择字符。
- 重复步骤 1 到 6 ,直到 s 中所有字符都已经被选过。
在任何一步中,如果最小或者最大字符不止一个 ,你可以选择其中任意一个,并将其添加到结果字符串。
请你返回将 s
中字符重新排序后的 结果字符串 。
示例 1:
输入:s = "aaaabbbbcccc" 输出:"abccbaabccba" 解释:第一轮的步骤 1,2,3 后,结果字符串为 result = "abc" 第一轮的步骤 4,5,6 后,结果字符串为 result = "abccba" 第一轮结束,现在 s = "aabbcc" ,我们再次回到步骤 1 第二轮的步骤 1,2,3 后,结果字符串为 result = "abccbaabc" 第二轮的步骤 4,5,6 后,结果字符串为 result = "abccbaabccba"
示例 2:
输入:s = "rat" 输出:"art" 解释:单词 "rat" 在上述算法重排序以后变成 "art"
示例 3:
输入:s = "leetcode" 输出:"cdelotee"
示例 4:
输入:s = "ggggggg" 输出:"ggggggg"
示例 5:
输入:s = "spo" 输出:"ops"
提示:
1 <= s.length <= 500
s
只包含小写英文字母。
如果想查看本题目是哪家公司的面试题,请参考以下免费链接: https://leetcode.jp/problemdetail.php?id=1370
解题思路分析:
本题我们先统计出字符串中每种字符的个数,然后先按照从a到z的顺序循环一遍,如果当前字符个数大于0,我们使用一个添加到返回结果,同时当前字符个数减一。然后再从z到a循环一次。重复上述操作,直到所有字符都使用完(返回结果长度等于原字符长度)为止。
实现代码:
public String sortString(String s) { // 字符串中每种字符个数 int[] count=new int[26]; // 统计每种字符个数 for(int i=0;i<s.length();i++){ count[s.charAt(i)-'a']++; } // 返回结果 StringBuilder sb = new StringBuilder(); while(sb.length()<s.length()){ // 从小到大取一个字母 for(int i=0;i<26;i++){ if(count[i]>0){ sb.append((char)('a'+i)); count[i]--; } } // 从大到小取一个字母 for(int i=25;i>=0;i--){ if(count[i]>0){ sb.append((char)('a'+i)); count[i]--; } } } return sb.toString(); }
本题解法执行时间为3ms。
Runtime: 3 ms, faster than 82.71% of Java online submissions for Increasing Decreasing String.
Memory Usage: 39.5 MB, less than 100.00% of Java online submissions for Increasing Decreasing String.
本网站文章均为原创内容,并可随意转载,但请标明本文链接如有任何疑问可在文章底部留言。为了防止恶意评论,本博客现已开启留言审核功能。但是博主会在后台第一时间看到您的留言,并会在第一时间对您的留言进行回复!欢迎交流!
本文链接: https://leetcode.jp/leetcode-1370-increasing-decreasing-string-解题思路分析/
《LEETCODE 1370. Increasing Decreasing String 解题思路分析》有1条回应