1.Two Sum
프로 그래 밍 언어: 자바
첫 번 째 시도: 보통 두 개의 for 순환 을 사용 하여 주어진 배열 의 수 를 찾 아 다 니 며 두 수의 합 을 계산 하 는 것 입 니 다. 두 개의 숫자 와 목표 숫자 가 있 을 때 순환 을 뛰 어 내 려 이 두 숫자의 아래 표 시 를 되 돌려 줍 니 다.
class Solution {
public int[] twoSum(int[] nums, int target) {
int[] result = new int[2];
A:for(int i=0;i
인터넷 에서 보면 이런 기본 적 인 방법 은 문 제 를 해결 할 수 있 지만 빠 르 지도 않 고 강요 도 부족 하 다. 누군가가 hashMap 으로 이 문 제 를 해결 하 는 것 을 보 았 다. 샤 오 백 은 hashmap 를 배 운 적 이 없 기 때문에 이 기 회 를 빌려 공부 하 는 김 에 배 웠 다.hashmap 를 사용 하여 원래 알고리즘 의 시간 복잡 도 를 O (N) 에서 O (1) 로 낮 추고 key 저장 수치, value 저장 에 나타 난 위 치 를 이전 뒤로 옮 겨 다 니 며 목표 값 으로 현재 값 을 빼 고 map 에 존재 하 는 지 확인 하고 존재 하면 해당 하 는 레이 블 을 꺼 내 종료 합 니 다.Best Practice:
public int[] twoSum(int[] nums, int target) {
int[] answer = new int[2];
HashMap map = new HashMap<>();
for (int i = 0; i < nums.length; ++i){
map.put(nums[i], i);
}
for (int i = 0; i < nums.length; ++i){
int b = target - nums[i];
if (map.containsKey(b) && i != map.get(b))
return new int[]{i, map.get(b)};
}
return answer;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.