/*思路 将想要转换的子串截取出 逆序存取进 字符数组中 在把字符数组 转换成 字符串 在替换 如果子串重复 则需要改进*/
public String myConverse(int start, int end,String str) {//有bug 如果子串重复出现 则全部替换
if(start > 0 && end > 0 && end > start && end < str.length()){
String str1 = str.substring(start, end+1);
String str_start = str.substring(0,start);
//System.out.println(str_start);
String str_end = str.substring(end+1,str.length());
//System.out.println(str_end);
String str_new ;//最后拼接成的字符串
char[] ch = new char[end+1 - start];
int k = end+1-start;
for(int i = 0; i < k; i++)
{
ch[i] = str1.charAt(k-i-1);
}
String str2 = String.valueOf(ch);
//System.out.println(str2);
//System.out.println(str1 + k);
//String str3 = str.replaceAll(str1, str2);
str_new = str_start + str2 +str_end;
return str_new;
}
else
{
System.out.println("您输入的参数有误!!");
return "";
}
}
public String myConverse(int start, int end,String str) {//有bug 如果子串重复出现 则全部替换
if(start > 0 && end > 0 && end > start && end < str.length()){
String str1 = str.substring(start, end+1);
String str_start = str.substring(0,start);
//System.out.println(str_start);
String str_end = str.substring(end+1,str.length());
//System.out.println(str_end);
String str_new ;//最后拼接成的字符串
char[] ch = new char[end+1 - start];
int k = end+1-start;
for(int i = 0; i < k; i++)
{
ch[i] = str1.charAt(k-i-1);
}
String str2 = String.valueOf(ch);
//System.out.println(str2);
//System.out.println(str1 + k);
//String str3 = str.replaceAll(str1, str2);
str_new = str_start + str2 +str_end;
return str_new;
}
else
{
System.out.println("您输入的参数有误!!");
return "";
}
}