RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1611084
Accepted
user709676
user709676
Asked:2025-05-01 04:17:48 +0000 UTC2025-05-01 04:17:48 +0000 UTC 2025-05-01 04:17:48 +0000 UTC

优化简单代码(String.valueOf)

  • 772

任务如下:

输入输出数据:

数据示例:

我解决了这个问题,但是在我的算法中我使用 String.valueOf 方法将数组的每个元素转换为字符串,这占用了大量的内存。我该如何优化我的代码?

public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);
    int n = scanner.nextInt();
    int k = scanner.nextInt();
    int[] list = new int[n + 1];
    for (int i = 0; i < n; i++) {
        list[i] = scanner.nextInt();
    }
    System.out.println(findMaxDifference(list,k));
}

public static long findMaxDifference(int[] list, int k) {
    long result = 0;
    for (int i = 0; i < k; i++) {
        list = refactorNum(list);
        result += list[list.length - 1]; // увеличиваю результат по последнему индексу массива
        list[list.length - 1] = 0; // обновляю его
    }
    return result;
}

private static int[] refactorNum(int[] list) {
    int prevIndex = -1;
    int prevValue = -1;
    for (int i = 0; i < list.length-1; i++) {
        String stringNum = String.valueOf(list[i]); // (проблема) создаю n*k объектов String
        for (int j = 0; j < stringNum.length(); j++) {
            if (stringNum.charAt(j) != '9') {
                stringNum = stringNum.replaceFirst(String.valueOf(stringNum.charAt(j)),"9");
                int parsedInt = Integer.parseInt(stringNum);
                if (parsedInt - list[i] > list[list.length-1]) {
                    if (prevIndex != -1) {
                        list[prevIndex] = prevValue;
                    }
                    prevIndex = i;
                    prevValue = list[i];
                    list[list.length-1] = parsedInt - list[i]; // ожидаемый результат
                    list[i] = parsedInt;
                }
                break;
            }
        }
    }
    return list;
}

}

java
  • 1 1 个回答
  • 22 Views

1 个回答

  • Voted
  1. Best Answer
    Stanislav Volodarskiy
    2025-05-01T06:17:57Z2025-05-01T06:17:57Z

    是的,您确实进行了nk次操作才得到结果。太多了,不是因为内存,而是因为速度。您可以使用nlogn进行管理。

    假设输入数字为12345。利用他的数字可以获得哪些“增长”?我们从九中减去每个数字,并根据数字中的位置号为其添加零:

    12345→80000、7000、600、50、4。

    我们将把所有输入数字转换成这样的“增加”集合。我们将“增加”收集到一个列表中,按降序排序并计算该列表前k 个元素的总和:

    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.Comparator;
    import java.util.List;
    import java.util.Scanner;
    
    public class Temp {
        public static void main(String... args) {
            Scanner sc = new Scanner(System.in);
            int n = sc.nextInt();
            int k = sc.nextInt();
    
            List<Integer> diffs = new ArrayList<>();
            for (int i = 0; i < n; ++i) {
                String s = sc.next();
                int p10 = 1;
                for (int j = s.length() - 1; j >= 0; --j) {
                    diffs.add((9 - (s.charAt(j) - '0')) * p10);
                    p10 *= 10;
                }
            }
            diffs.sort(Collections.reverseOrder());
            if (k < diffs.size()) {
                diffs = diffs.subList(0, k);
            }
            long sum = 0;
            for (int d : diffs) {
                sum += d;
            }
            System.out.println(sum);
        }
    }
    

    最有可能的是,该任务将以这种形式被接受。但还可以做得更好。请注意,“增加”仅存在形式为d·10 j的增加,其中0 ≤ d ≤ 9。也就是说,不同的选择不超过九十种。这意味着,您无需进行排序,而是可以在n + k时间内安排一个即兴的计数排序,这比nlogn更好。并且仅需要常量内存。

    import java.util.Scanner;
    
    public class Temp {
        public static void main(String... args) {
            Scanner sc = new Scanner(System.in);
            int n = sc.nextInt();
            int k = sc.nextInt();
    
            int[] p10 = new int[9];
            for (int j = 0, p = 1; j < 9; ++j, p *= 10) {
                p10[j] = p;
            }
    
            int[][] diffs = new int[9][10];
            for (int i = 0; i < n; ++i) {
                String s = sc.next();
                for (int j = s.length() - 1; j >= 0; --j) {
                    ++diffs[s.length() - j - 1][9 - (s.charAt(j) - '0')];
                }
            }
    
            long sum = 0;
            for (int j = p10.length - 1; j >= 0; --j) {
                for (int d = 9; d >= 0; --d) {
                    int r = Math.min(diffs[j][d], k);
                    sum += d * r * p10[j];
                    k -= r;
                }
            }
            System.out.println(sum);
        }
    }
    
    • 1

相关问题

  • wpcap 找不到指定的模块

  • 如何以编程方式从桌面应用程序打开 HTML 页面?

  • Android Studio 中的 R.java 文件在哪里?

  • HashMap 初始化

  • 如何使用 lambda 表达式通过增加与原点的距离来对点进行排序?

  • 最大化窗口时如何调整元素大小?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5