题目概述
- 算法说明
汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它! - 测试用例
输入:
“abcXYZdef”,3
返回值:
“XYZdefabc”
解析&参考答案
- 解析
比较简单,直接先获取右边部分,然后在获取左边部分即可 - 参考答案
vim jz43.go
package main
import "fmt"
func LeftRotateString(str string, n int) string {
if str == "" {
return str
}
n = n % len(str)
return str[n:] + str[:n]
}
func main() {
str := "abcXYZdef"
n := 3
result := LeftRotateString(str, n)
fmt.Println(result)
}
注意事项
- to add
说明
- 当前使用 go1.15.8
- 参考 牛客网--剑指offer
标题中jzn(n为具体数字)代表牛客网剑指offer系列第n号题目,例如 jz01 代表牛客网剑指offer中01号题目。
注意!!!
- 笔者最近在学习 golang,因此趁机通过数据结构和算法来进一步熟悉下go语言
- 当前算法主要来源于剑指 offer,后续会进一步补充 LeetCode 上重要算法,以及一些经典算法
- 此处答案仅为参考,不一定是最优解,欢迎感兴趣的读者在评论区提供更优解