在LeetCode刷题的过程中遇到了一道题解答如下:
List<String> list = new ArrayList<>();
Arrays.sort(hand);
for (int i: hand){
list.add(i+"");
}
for (int i = 0; i < hand.length / W; i++){
int first = Integer.parseInt(list.get(0));
for (int j = 0; j < W; j++){
list.remove(first+j+"");
}
}
提交后返回超时。在无法降低时间或空间复杂度的情况下尝试使用s=String.valueOf(i);的方式替代s=i+"";使int类型转为String类型。成功通过提交。
修改后代码:
List<String> list = new ArrayList<>();
Arrays.sort(hand);
for (int i: hand){
list.add(String.valueOf(i));
}
for (int i = 0; i < hand.length / W; i++){
int first = Integer.parseInt(list.get(0));
for (int j = 0; j < W; j++){
list.remove(String.valueOf(first+j));
}
}
原因:s=i+""; 会产生两个String对象,而 s=String.valueOf(i); 直接使用String类的静态方法,只产生一个对象。没有内存分配的过程,使程序运行时间降低通过提交。
不知道s=i+""相对 s=String.valueOf(i)有什么优势?知道的同学欢迎在评论下面留言。