inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

더 개발자, 인터뷰 가이드

배열 문제 3

배열 문제 3 - solution2

101

S.F.

작성한 질문수 3

0

기선님 안녕하세요.

문제를 풀다가 궁금한 점이 생겨서 질문드립니다.

 

배열 문제 3의 solution2와 관련된 질문입니다.

private int[] solution2(int[] nums, int target) {
    HashMap<Integer, Integer> numberMap = new HashMap<>();

    for (int i = 0; i < nums.length; i++) {
        if (numberMap.containsKey(target - nums[i]) && numberMap.get(target - nums[i]) != i) {
            return new int[]{numberMap.get(target - nums[i]), i};
        } else {
            numberMap.put(nums[i], i);
        }
    }

    return null;
}

 

상단 코드의 if 조건문에서 "numberMap.get(target - nums[i]) != i" 이부분이 반드시 필요한지, 아니면 없어도 똑같은 결과를 도출할 수 있는 지가 궁금합니다.

제가 생각하기에는 배열을 1회만 순회하기 때문에 상기한 조건이 없어도 똑같은 결과가 나올 것 같은데 기선님의 생각이 궁금합니다. 답변 부탁드립니다.

 

 

코딩-테스트 면접

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. S.F.님.

문의하신 내용에 대한 설명과 유사한 질문 및 답변을 찾아 보았습니다.

이 함수는 두 숫자의 합이 target이 되는 두 숫자의 인덱스를 반환하는 문제를 해결하는 함수입니다. 여기서 핵심은 조건문 내의 numberMap.get(target - nums[i]) != i 부분입니다. 이 부분의 역할은 동일한 인덱스를 두 번 참조하는 경우를 방지합니다. 예를 들어, (4, 2)에서 target을 6으로 맞추기 위해 (nums[i] = 4)(nums[j] = 2)에서 j가 i와 같은 인덱스를 가리키지 않도록 합니다.

해당 조건이 없다면, 두 숫자가 같은 경우를 해결하지 못할 수 있습니다(예: [3, 3]에서 target이 6인 경우).

더 많은 이해와 관련된 문제 해결을 돕기 위한 유사한 질문을 아래 링크에서 찾아 참고해 보실 수 있습니다:

  1. 한번 배워본 대로 문제를 풀어보았습니다. - 배열 내 유일한 요소를 찾기 위한 방법에 대한 질문입니다.

이 내용이 도움이 되셨기를 바랍니다. 추가적인 궁금한 점이 있으시면, 꼭 질문해 주시기 바랍니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

REST API (Self-descriptive messages)

0

5

0

2주차 개념#12 트리 순회

0

14

2

프로필 사진 세팅과 관련하여 질문 드립니다

1

29

2

백준 사이트 서비스 종료

0

38

3

잠겨버린 사물함 시간초과 관련 질문입니다.

0

17

1

프로젝트 질문 문의

0

37

1

시스템 엔지니어 관련 질문입니다.

0

39

2

백준 서비스 종료인데 도전 과제 프로그래머스 문제로 올려주실수 있으신가요

0

64

1

백준사이트가 종료된다고 합니다.

0

214

2

www.nossi.dev 사이트 접근 불가 오류

0

23

1

백준 서비스 종료

9

682

1

구글 폼 작성 완료!

1

30

1

코딩테스트 처음인데 이런 공부방법이어도 괜찮을까요

0

40

1

미국 취업

0

58

1

인터뷰 미션 보냈습니다.

0

145

2

혹시 미국은 설 연휴때 어떻게 보내시나요

0

289

2

강의 자료

0

198

2

오타 제보합니다.

0

277

2

이력서 미션 보냈습니다.

0

549

1

미션 관련 내용 질문 있습니다..!

0

402

1

미션 수행 방법 질문드립니다.

0

422

1

코딩인터뷰 때 손코딩, 화이트보드에 코딩시키는 이유가 있나요?

0

2993

2

안녕하세요. 깃발 보고 싶은데

0

462

2

깃발이 보이지 않습니다

0

494

1