Hôm nay khi tôi gửi một giải pháp cho codeforces, tôi đã sử dụng int [] mảng và gửi của tôi có TLE (Thời gian vượt quá giới hạn) & sau khi thay đổi nó thành Integer [] mảng đáng ngạc nhiên nó có AC. Tôi đã không nhận được hiệu suất được cải thiện như thế nào.hiệu suất của int Array vs Integer Array
import java.io.*;
import java.lang.reflect.Array;
import java.util.*;
public class Main {
static class Task {
public void solve(InputReader in, PrintWriter out) throws Exception {
int n = in.nextInt();
Integer[] a = new Integer[n];
for (int i = 0; i < n; i++) a[i] = in.nextInt();
Arrays.sort(a);
long count = 0;
for (int i = 0; i < n; i++) count += Math.abs(i + 1 - a[i]);
out.println(count);
}
}
public static void main(String[] args) throws Exception{
InputStream inputStream = System.in;
OutputStream outputStream = System.out;
InputReader in = new InputReader(inputStream);
PrintWriter out = new PrintWriter(outputStream);
Task task = new Task();
task.solve(in, out);
out.close();
}
static class InputReader {
public BufferedReader reader;
public StringTokenizer tokenizer;
public InputReader(InputStream stream) {
reader = new BufferedReader(new InputStreamReader(stream), 32768);
tokenizer = null;
}
public String next() {
while (tokenizer == null || !tokenizer.hasMoreTokens()) {
try {
tokenizer = new StringTokenizer(reader.readLine());
} catch (IOException e) {
throw new RuntimeException(e);
}
}
return tokenizer.nextToken();
}
public int nextInt() {
return Integer.parseInt(next());
}
}
}
@ sotirios-delimanolis bạn có thể giải thích nơi autoboxing xảy ra không? Nếu mảng là kiểu 'int []', không nên có auto (un) boxing. – Turing85
@NaveenKakani auto (un) boxing không áp dụng ở đây, hoặc ít nhất là không theo cách tích cực. Từ những gì tôi thấy, auto (un) boxing nên làm cho code của bạn chậm hơn, không nhanh. Tái bút: [liên kết đến hướng dẫn của Oracle về autoboxing] (https://docs.oracle.com/javase/tutorial/java/data/autoboxing.html). – Turing85
@NaveenKakani điều duy nhất bạn thay đổi là loại mảng 'a' trong' giải quyết (...) 'từ' int [] 'thành' Integer [] 'và chương trình của bạn nhanh hơn? – Turing85