题目
给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。
如果剩余字符少于 k 个,则将剩余字符全部反转。
如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。
示例 1:
输入:s = “abcdefg”, k = 2
输出:“bacdfeg”
示例 2:
输入:s = “abcd”, k = 2
输出:“bacd”
分析
这个的区别的就在于,他是有固定规律的翻转,不是全部都进行翻转,难点也就是在怎样判断该进行翻转的区间。
代码
var reverseStr = function(s, k) {
//翻转字符
function raverseWord(str,left,right){
while(left<right){
let temp = str[left]
str[left] = str[right]
str[right] = temp
left++
right--
}
}
let str = s.split("")
let n = parseInt(str.length/(2*k))
let dif = str.length%(2*k)
for(let i=0; i<n; i++){
raverseWord(str,2*i*k,(2*i+1)*k-1)
}
if(dif<k){
raverseWord(str,2*n*k,2*n*k+dif-1)
}else{
raverseWord(str,2*n*k,2*n*k+k-1)
}
return str.join("")
};
注意
我犯了一个超级小的错误,却怎么也没察觉,要注意join方法是这样用的str.join(’’),我却粗心的写成了str.join()怎么也没有觉察到是哪里错了,大家要十分注意这一点,