Golang | Leetcode Golang题解之第443题压缩字符串
题目:
题解:
func compress(chars []byte) int {
write, left := 0, 0
for read, ch := range chars {
if read == len(chars)-1 || ch != chars[read+1] {
chars[write] = ch
write++
num := read - left + 1
if num > 1 {
anchor := write
for ; num > 0; num /= 10 {
chars[write] = '0' + byte(num%10)
write++
}
s := chars[anchor:write]
for i, n := 0, len(s); i < n/2; i++ {
s[i], s[n-1-i] = s[n-1-i], s[i]
}
}
left = read + 1
}
}
return write
}
原文地址:https://blog.csdn.net/weixin_66442839/article/details/142625533
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!