【发布时间】:2017-02-12 08:04:59
【问题描述】:
我正在尝试 UVa 问题编号10324 我编写了以下解决方案,这得到了接受,但给出了一个非常糟糕的 2.670 秒运行时间 我有以下两个代码 这是我的代码
public static void main(String[] args) throws Exception{
// write your code here
StringBuilder op = new StringBuilder();
InputStreamReader isr = new InputStreamReader(System.in);
BufferedReader reader = new BufferedReader(isr);
String input, tmp[];
int n, l, u, j, i = 0;
boolean dec;
char thi;
while ((input = reader.readLine()) != null) {
op.append("Case " + (++i) + ":\n");
n = Integer.parseInt(reader.readLine());
while (n-- > 0) {
tmp = reader.readLine().split(" ");
l = Integer.parseInt(tmp[0]);
u = Integer.parseInt(tmp[1]);
if (l > u) {
l ^= u;
u ^= l;
l ^= u;
}
//System.out.println(l + "|" + u);
dec = true;
thi = input.charAt(l++);
for (; l <= u; l++) {
if (thi != input.charAt(l)||(thi != input.charAt(u--))) {
dec = false;
break;
}
}
op.append((dec ? "Yes\n" : "No\n"));
}
}
System.out.print(op.toString());
return;
}
}
另一个代码是我从Mr Gorgon's Solution 中找到的 运行时间为 0.84 秒
public static void main(String[] args) throws Exception {
InputStreamReader isr = new InputStreamReader(System.in);
BufferedReader br = new BufferedReader(isr);
StringBuilder sb = new StringBuilder("");
int testCase = 1;
String line;
while ((line = br.readLine()) != null) {
sb.append("Case ").append(testCase).append(":\n");
testCase++;
int noOfCases = Integer.parseInt(br.readLine());
for (int j = 0; j < noOfCases; j++) {
String[] str = br.readLine().split(" ");
int val1 = Integer.parseInt(str[0]);
int val2 = Integer.parseInt(str[1]);
if (val1 > val2) {
val1 ^= val2;
val2 ^= val1;
val1 ^= val2;
}
boolean isValid = true;
if (val1 != val2) {
for (int i = val1; i < val2; i++) {
if (line.charAt(i) != line.charAt(i + 1)) {
isValid = false;
break;
}
}
}
if (isValid)
sb.append("Yes\n");
else
sb.append("No\n");
}
}
System.out.print(sb);
}
我发现在所有任务基本相同的情况下,我很难理解为什么这段代码运行得这么快。而且我的代码比 Gorgons 代码的声明更少
【问题讨论】:
-
声明实际上并没有真正增加太多的性能开销(而且我没有看到你真的有任何声明更少......)
-
我用几个很长的字符串和很多较短的字符串创建了一些测试用例,并在本地运行了两个版本(windows 和 linux,jdk8),你的版本快了大约 2 倍。了解他们的(UVa)实际测试用例和他们使用的 java 运行时会很有趣。
标签: java performance optimization time