对于一个字符串,和字符串中的某一位置,请设计一个算法,将包括i位置在内的左侧部分移动到右边,将右侧部分移动到左边。
给定字符串A和它的长度n以及特定位置p,请返回旋转后的结果。
测试样例:
"ABCDEFGH",8,4
返回:"FGHABCDE"
import java.util.*;
public class StringRotation {
public String rotateString(String A, int n, int p) {
return A.substring(p+1,A.length())+A.substring(0,p+1);
}
}
import java.util.*;
//两次分别翻转,再整体翻转。前面都说了很多了,就不赘述了,仅来签到而已
public class StringRotation {
public String rotateString(String str, int n, int p) {
String strA = str.substring(0,p+1);
String strB = str.substring(p+1,n);
StringBuilder sbA = new StringBuilder(strA);
StringBuilder sbB = new StringBuilder(strB);
strA = sbA.reverse().toString();
strB = sbB.reverse().toString();
StringBuilder sb = new StringBuilder(strA+strB);
String res = sb.reverse().toString();
return res;
}
}
import java.util.*;
public class StringRotation {
public String rotateString(String A, int n, int p) {
String s1=A.substring(0, p+1);
String s2=A.substring(p+1);
s1=rotate(s1);
s2=rotate(s2);
A=s1+s2;
A=rotate(A);
return A;
}
private String rotate(String a) {
StringBuffer sb=new StringBuffer();
char[] sh=a.toCharArray();
for(int i=a.length()-1;i>=0;i--){
sb.append(sh[i]);
}
return sb.toString();
}
}