처음으로 Java
를 활용해서 풀어보았습니다. 스프링 부트 개발자를 지향하기에 활용하는 언어에 익숙해지는게 우선이라 생각했어요. 그럼 시작하겠습니다.
Given an array of integers nums and an integer target, return indices of the two numbers such that they add up to target.
You may assume that each input would have exactly one solution, and you may not use the same element twice.
You can return the answer in any order.
정수가 담긴 배열과 숫자target
가 주어졌을 때, 배열 요소를 합한 값이 target
이 되는 2개의이배열 인덱스를 반환하는 문제입니다.
제한 및 기타사항으로 봤을 때 알 수 있는 요소가,
이를 통해 생각해낸 접근법은 배열 요소 내 숫자를 key
로, 인덱스 값을 value
둔 HashMap
을 사용하는 것이었습니다.
처음엔 HashMap
에 미리 초기화를 하고 진행하는 방식을 생각했으나, 예제에서 봤을 때 중복된 숫자가 존재할 수 있다는 사실이었습니다.
이를 해결하기 위한 접근 방법이,
target
- 현재 숫자를 key
, 인덱스를 value
로 HashMap
에 추가합니다.HashMap
을 사전에 초기화하지 않아요.)HashMap
에 검색해서 존재하면 target
- 숫자의 값을 이미 처리했단 의미가 되어 HashMap
의 해당 인덱스 값과 현재 인덱스 값을 담은 배열을 반환합니다.이 경우 for문을 한번만 수행하기 때문에 기본 로직 시간 복잡도는 O(n)이 되나 중간에 HashMap
검색과 추가의 경우 각각 최악의 경우 O(n)이긴 하나, 평균적으로 O(1)이 되므로 O() 이하의 시간 복잡도를 기대할 수 있겠습니다.
import java.util.HashMap;
import java.util.Map;
public class Solution {
public int[] twoSum(int[] nums, int target) {
Map<Integer, Integer> checkMap = new HashMap<>();
for(int nIndex = 0 ; nIndex < nums.length; ++nIndex){
final int num = nums[nIndex];
if(checkMap.containsKey(num))
{
return new int[]{ checkMap.get(num), nIndex };
}
checkMap.put(target - num, nIndex);
}
return new int[]{-1, -1};
}
}