Problem
Problem_Link
Solutions (time, space)
O(n^2), O(n)
class Solution {
public int[] createTargetArray(int[] nums, int[] index) {
List<Integer> temp = new ArrayList<Integer>();
int[] target = new int[nums.length];
for(int i=0;i<nums.length;i++) temp.add(index[i],nums[i]);
target = temp.stream().mapToInt(Integer::intValue).toArray();
return target;
}
}
Explanation
data:image/s3,"s3://crabby-images/2531c/2531c3c983385c05db1db16a1a103a5814642e15" alt=""
- put values in arraylist as index then convert to int array from arraylist.
- in worst case, it is O(n^2).
- There is another way, pair index and value then merge sort.O(n log n)
- If problem must not reach O(n^2), should use merge sort.