Итак, я пытаюсь решить проблему 3Sum в Leetcode. Мое решение получает правильный ответ, однако с более длинными тестами я получаю «Превышен лимит времени». Я предполагаю, что это из-за вложенных циклов for, которые я использую, но я не уверен, что делать дальше.
class Solution {
public List<List<Integer>> threeSum(int[] nums) {
int x = 0;
int y = 0;
int z = 0;
Arrays.sort(nums);
List<List<Integer>> res = new ArrayList<>();
Map<Integer,Integer> map = new HashMap();
for (int i = 0; i < nums.length; i++){
map.put(i, nums[i]);
}
for (int j = 0; j < nums.length - 2; j++){
x = map.get(j);
for(int k = j+1;k < nums.length - 1; k++){
y = map.get(k);
for(int l = k+1; l <nums.length; l++){
z = map.get(l);
if((x + y + z) == 0){
List<Integer> triplet = new ArrayList<Integer>();
triplet.add(x);
triplet.add(y);
triplet.add(z);
System.out.println(triplet);
if (!(res.contains(triplet))){
res.add(triplet);
}
}
}
}
}
return res;
}
Какие-либо советы о том, как оптимизировать это решение?