zoukankan      html  css  js  c++  java
  • Java int类型转String类型两种方式性能差异

    在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)有什么优势?知道的同学欢迎在评论下面留言。

  • 相关阅读:
    办公自动化15-一次性生成多层目录
    小技巧1-查看excel中工作表(sheet)的个数
    LaTex 公式编辑
    Cpp 学习网站
    函数的凹凸性
    二项分布
    函数间断点
    霍夫丁(Hoeffding)不等式
    数域
    马尔可夫(Markov)不等式
  • 原文地址:https://www.cnblogs.com/gene1994/p/9560318.html
Copyright © 2011-2022 走看看