「LeetCode」剑指Offer-58-II左旋转字符串⚡️

简介: 「LeetCode」剑指Offer-58-II左旋转字符串⚡️

image.png

前言🌧️


算法,对前端人来说陌生又熟悉,很多时候我们都不会像后端工程师一样重视这项能力。但事实上,算法对每一个程序员来说,都有着不可撼动的地位。

因为开发的过程就是把实际问题转换成计算机可识别的指令,也就是《数据结构》里说的,「设计出数据结构,在施加以算法就行了」。


当然,学习也是有侧重点的,作为前端我们不需要像后端开发一样对算法全盘掌握,有些比较偏、不实用的类型和解法,只要稍做了解即可。


题目🦀



剑指 Offer 58 - II. 左旋转字符串


难度简单


字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。



示例 1:


输入: s = "abcdefg", k = 2
输出: "cdefgab"


示例 2:


输入: s = "lrloseumgh", k = 6
输出: "umghlrlose"


限制:


  • 1 <= k < s.length <= 10000


解题思路🌵



  • split分割字符为数组
  • reverse将数组翻转
  • 最后join


解法1🔥


var reverseLeftWords = function(s, n) {
    return `${s.slice(n)}${s.slice(0,n)}`
};

时间复杂度:O(n)


空间复杂度:O(1)


解法2🔥


var reverseLeftWords = function(s, n) {
    let arr=s.split('')
    const remove=arr.splice(0,n)
    arr=arr.concat(remove)
    return arr.join('')
};

时间复杂度:O(n)


空间复杂度:O(1)


结束语🌞



image.png


那么鱼鱼的LeetCode算法篇的「LeetCode」剑指Offer-58-II左旋转字符串⚡️就结束了,算法这个东西没有捷径,只能多写多练,多总结,文章的目的其实很简单,就是督促自己去完成算法练习并总结和输出,菜不菜不重要,但是热爱🔥,喜欢大家能够喜欢我的短文,也希望通过文章认识更多志同道合的朋友,如果你也喜欢折腾,欢迎加我好友,一起沙雕,一起进步

相关文章
|
2天前
|
算法
力扣每日一题 6/23 字符串/模拟
力扣每日一题 6/23 字符串/模拟
5 1
|
2天前
力扣经典150题第四十题:同构字符串
力扣经典150题第四十题:同构字符串
6 1
|
1天前
|
索引
力扣每日一题 6/27 字符串 贪心
力扣每日一题 6/27 字符串 贪心
4 0
|
1天前
|
Python
力扣随机一题 模拟+字符串
力扣随机一题 模拟+字符串
4 0
|
2天前
力扣每日一题 6/22 字符串/贪心
力扣每日一题 6/22 字符串/贪心
4 0
|
2天前
力扣每日一题 6/18 字符串/模拟
力扣每日一题 6/18 字符串/模拟
4 0
|
1天前
|
算法
力扣每日一题 6/16 字符串 + 随机一题 动态规划/数学
力扣每日一题 6/16 字符串 + 随机一题 动态规划/数学
5 0
|
15天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-2
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
15天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-1
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
16天前
|
索引
【LeetCode刷题】二分查找:山脉数组的峰顶索引、寻找峰值
【LeetCode刷题】二分查找:山脉数组的峰顶索引、寻找峰值