周末在刷算法,一个算法题的要求是,给出一个字符串,将指定索引处的单词顺序翻转,其他位置单词不变,例如给sing一个字符串
String s=“I am a code”,指定翻转0-2的单词顺序,结果变成
String s=“a sm I code”
当时卡了一会儿,现在写出来了,特记录一下
import java.util.ArrayList;
import java.util.List;
public class Test {
public static void main(String[] args) {
String s="i am a java";
System.out.println(reverseStr(s,1,2));
}
public static String reverseStr(String s,int start,int end){
String[] arr=s.split(" ");
List<String> arrList=new ArrayList<String>();
for (int i=0;i<arr.length;i++){
arrList.add(arr[i]);
}
for (int i=start;i<=end;i++){
arrList.set(i,arr[arr.length-1-i]);
}
String ss="";
for (int i=0;i<arrList.size();i++){
ss+=arrList.get(i)+" ";
}
return ss;
}
}
这里主要是看到文档,知道了ArrayList中有一个方法set(int index,T t),set()方法是更新指定索引的数据,add()是在指定索引处插入值,是数据的新增。