leetcode之一题学会Golang字符串怎么用
2020-03-22 18:28
393 查看
题目
面试题 01.06. 字符串压缩
字符串压缩。利用字符重复出现的次数,编写一种方法,实现基本的字符串压缩功能。比如,字符串aabcccccaaa会变为a2b1c5a3。若“压缩”后的字符串没有变短,则返回原先的字符串。你可以假设字符串中只包含大小写英文字母(a至z)。
示例1:
输入:"aabcccccaaa" 输出:"a2b1c5a3"
示例2:
输入:"abbccd" 输出:"abbccd" 解释:"abbccd"压缩后为"a1b2c2d1",比原字符串长度更长。
提示:
字符串长度在[0, 50000]范围内。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/compress-string-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
Golang之字符串
Golang的内置函数len()返回一个字符串中的字节数目。索引操作s[i]返回的是第i个字节的字节值,且0<=i<len(s)。
由于本题需要返回字符串,因此要么可以使用slice,比如s[0:1]表示字符串,要么可以将字节数组转成字符串类型。
执行用时:72 ms 内存消耗:7.8 MB func compressString(S string) string { if len(S)<2 { return S } var mystring string ch := S[0:1] num := 1 for i:=1;i<len(S);i++ { if ch==S[i:i+1] { num++ } else { mystring += ch+strconv.Itoa(num) ch = S[i:i+1] num = 1 } } mystring += ch+strconv.Itoa(num) if len(S)>len(mystring) { return mystring } else { return S } }
经验证,使用[]byte处理字符串,最后使用string转化为字符串类型处理速度更快,更省内存。
执行用时:0 ms 内存消耗:3.1 MB func compressString(S string) string { if S == "" { return "" } cache := make([]byte, 0) count := 1 prev := S[0] for i := 1; i < len(S); i++ { if prev != S[i] { cache = append(cache, prev) cache = append(cache, strconv.Itoa(count)...) count = 1 } else { count++ } prev = S[i] } cache = append(cache, prev) cache = append(cache, strconv.Itoa(count)...) if len(cache) < len(S) { return string(cache) } return S }
总结
Golang字符串其实是[]byte。可以直接使用string转化为字符串类型。字符串使用slice方式进行运算操作效率不如[]byte。
- 点赞
- 收藏
- 分享
- 文章举报
相关文章推荐
- golang_算法: leetcode_字符串01-反转字符串
- golang_算法: leetcode_字符串09-最长公共前缀
- 【Golang】LeetCode-剑指Offer-面试题48-最长不含重复字符的子字符串
- 【Golang】LeetCode-剑指Offer-面试题46-把数字翻译成字符串
- golang_算法: leetcode_字符串02-整数反转
- golang_算法: leetcode_字符串03-字符串中的第一个唯一字符
- golang_算法: leetcode_字符串05-验证回文字符串
- golang_算法: leetcode_字符串06-字符串转换整数 (atoi)
- golang_算法: leetcode_字符串07-实现strStr()
- 【Golang】LeetCode-剑指Offer-面试题38-字符串的排列
- golang_算法: leetcode_字符串04-有效的字母异位词
- 字符串-leetcode 521 Longest Uncommon Subsequence I
- [leetcode, python] Reverse Words in a String 反转字符串
- Leetcode 字符串 Valid Palindrome
- LeetCode 443. String Compression (压缩字符串)
- 大学学的网络、出来后感觉自己啥也没学会哇~怎么办、有什么好书推荐吗~
- golang 字符串操作实例
- [LeetCode] Isomorphic Strings 同构字符串
- ThinkCMF框架写接口时不能正确输入json字符串而是带上了网页源码怎么办?
- Leetcode挑战:String to Integer(字符串转数值)