左旋转字符串——offer

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u014067137/article/details/81913775
汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。
对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。
例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!

 思路:字符串切割

当循环左移位数n>字符串长度[str.length()]时,需要进行取模运算

比如 字符串长度为10,左移13位,和左移3位是相等的效果    13%10=3

package arraydemo;
public class Solution5 {
	
	public static void main(String[] args) {
		String str="abcxyzdef";
		System.out.println(LeftRotateString(str, 3));
	}
	public static String LeftRotateString(String str,int n) {
		StringBuffer sb=new StringBuffer();
		if (str.length()==0 || n<0) {
			return sb.toString();
		}
		n=n%(str.length());//左移位数
		
		sb.append(str.substring(n, str.length()));
		sb.append(str.substring(0, n));
		
		return sb.toString();
	}
}

猜你喜欢

转载自blog.csdn.net/u014067137/article/details/81913775