对于一个字符串,和字符串中的某一位置,请设计一个算法,将包括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(); } }