gpt4 book ai didi

java - 有没有办法在不到 O(n) 的时间内连接 Java 字符串?

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:30:22 25 4
gpt4 key购买 nike

我的家庭作业问题涉及按特定顺序连接字符串。我们首先得到字符串,然后是一组告诉我们如何连接它们的指令;最后我们打印输出字符串。

我使用了 Kattis FastIO 类来处理缓冲输入和输出。下面是我的算法,它遍历指令以连接字符串。我尝试制作普通字符串数组、StringBuffers 和 StringBuilders。

该程序似乎按预期工作,但由于效率低下,它在我的提交平台上给出了时间限制错误。似乎附加我所做的方式是 O(n);有没有更快的方法?

public class JoinStrings {
public static void main(String[] args) {
Kattio io = new Kattio(System.in, System.out);
ArrayList<StringBuilder> stringList = new ArrayList<StringBuilder>();
int numStrings = io.getInt();
StringBuilder[] stringArray = new StringBuilder[numStrings];

for (int i = 0; i < numStrings; i++) {
String str = io.getWord();
stringArray[i] = new StringBuilder(str);
}

StringBuilder toPrint = stringArray[0];

while (io.hasMoreTokens()) {
int a = io.getInt();
int b = io.getInt();
stringArray[a-1].append(stringArray[b-1]); // this is the line that is done N times

toPrint = stringArray[a-1];
}

io.println(toPrint.toString());
io.flush();
}
}

最佳答案

StringBuilder.append() 将字符从新字符串复制到现有字符串。它速度很快,但不是免费的。

不是一直将字符串追加到 StringBuilder 数组,而是跟踪需要追加的字符串索引。然后最后追加存储在打印输出索引列表中的字符串。

关于java - 有没有办法在不到 O(n) 的时间内连接 Java 字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57950252/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com