美文网首页
(XYT=(YTXT)T)左旋转字符串

(XYT=(YTXT)T)左旋转字符串

作者: 壹豪 | 来源:发表于2019-08-13 10:19 被阅读0次

题目描述

汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!

思路

1.本题想考察的是反转,XY(T)=(Y(Y)X(T))(T),即XYT=(YTXT)T
2.(辅助空间)先取k位右边的字符串,然后把左边的字符串衔接上去即可(不适用substring为好)
3.(空间复杂度1)循环往左移动一位,然后n-1,一直到n=0

代码

//1.XYT=(YTXT)T写法
public class Solution {
    public String LeftRotateString(String str,int n) {
        //新建一个数组作为结果输出
        if(n==0)
            return str;
        if(str.length()<n)
            return "";
        char[] temp = str.toCharArray();
        reverse(temp,0,n-1);
        reverse(temp,n,temp.length-1);
        reverse(temp,0,temp.length-1);
        return new String(temp);
    }
    public void reverse(char[] chars,int i,int j){
        while(i<j){
            char temp = chars[i];
            chars[i] = chars[j];
            chars[j] = temp;
            i++;
            j--;
        }
    }
}
//2.辅助空间写法
public class Solution {
    public String LeftRotateString(String str,int n) {
        //新建一个数组作为结果输出
        String result = new String();
        if(n>str.length())
            return result;
        //取n位右边的字符串
        result = str.substring(n);
        //尾部衔接n左边的字符串
        result= result.concat(str.substring(0,n));
        return result;
    }
}

相关文章

  • (XYT=(YTXT)T)左旋转字符串

    题目描述 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。...

  • LeetCode题解之左旋转字符串

    左旋转字符串 题目描述 字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左...

  • 面试题58 - II. 左旋转字符串

    左旋转字符串 题目描述 字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左...

  • AVLtTree

    左旋转 右旋转 双旋转 左旋右旋规律 右旋右低,左旋左低,左高右旋,右高左旋左旋动左。右旋动右。新节点代替当前根节...

  • 旋转字符串 (lintcode:rotate-string)

    旋转字符串 给定一个字符串和一个偏移量,根据偏移量旋转字符串(从左向右旋转) 例如: 对于字符串 "abcdefg...

  • 旋转字符串

    旋转字符串

  • 蒙版

    ⒈先调整不透明度 Ctrl t 旋转以及调整图片使图片对齐 再讲透明度调回(shift 等比例放大缩小图片) ⒉左...

  • lintCode题解(8)

    标签(空格分隔): lintCode 旋转字符串 给定一个字符串和一个偏移量,根据偏移量旋转字符串(从左向右旋转)...

  • 判断字符串str1是否是字符串str2的旋转词

    判断字符串str1是否是字符串str2的旋转词 对字符串的旋转操作描述如下:例如: str = "123456" ...

  • 牛客/力扣算法题

    1.逆转字符串 2.旋转字符串

网友评论

      本文标题:(XYT=(YTXT)T)左旋转字符串

      本文链接:https://www.haomeiwen.com/subject/fbpyjctx.html