합이 0인 하위 배열이 있는지 찾는 JavaScript 프로그램
개발자로서 우리는 배열에 합이 0인 하위 배열이 있는지 찾아달라는 요청을 자주 받습니다. 이는 접두사 합계 개념을 사용하여 수행할 수 있습니다. 지금까지 본 하위 배열 요소의 합계를 추적하고 이를 해시맵에 저장합니다. 이전에 합계를 본 경우 해당 합계를 포함하는 하위 배열이 존재하고 합계는 0입니다. 우리는 지금까지 본 요소의 합계로 해시맵을 지속적으로 업데이트할 것입니다. 이런 방식으로 배열에 합이 0인 하위 배열이 있는지 확인할 수 있습니다.
방법
변수 "sum"을 0으로 초기화하고 "hash_map" 개체를 초기화하여 합계 값을 키로, 해당 인덱스를 값으로 저장합니다.
각 요소에 대해 주어진 배열을 반복합니다. -
현재 요소를 합계에 추가합니다.
합이 0인 하위 배열이 있으므로 현재 합계가 0이거나 hash_map에 이미 존재하는 경우 true를 반환합니다.
그렇지 않으면 합계 값과 해당 인덱스를 hash_map에 삽입하세요.
루프가 완료되면 합이 0이 되는 하위 배열이 없으므로 false를 반환합니다.
hash_map은 누적 합계를 추적하고 중복 합계가 있는지 확인하는 데 도움이 됩니다.
중복된 합계가 발견되면 두 합계 사이에 합계가 0인 하위 배열이 있다는 의미입니다.
이 방법의 시간 복잡도는 O(n)입니다. 여기서 n은 주어진 배열의 요소 수입니다.
예
합이 0인 하위 배열이 있는지 확인하는 완전한 JavaScript 프로그램 예는 다음과 같습니다. -
으아악지침
함수 hasZeroSum는 배열 arr을 인수로 사용합니다.
-
두 개의 변수 sum 및 set을 초기화합니다. sum 변수는 하위 배열 요소의 현재 합계를 추적하는 데 사용되고 set 변수는 이전에 확인된 합계를 저장하는 데 사용됩니다.
李> 그런 다음 for 루프를 사용하여 배열 요소를 반복합니다.
각 반복마다 현재 요소를 sum에 추가하고 set에 이미 sum 값이 포함되어 있는지 확인합니다.
sum 값이 이미 set에 있는 경우 는 이 합이 처음 나타나는 부분부터 현재 요소 끝까지의 하위 배열의 합이 0임을 의미하므로 true를 반환합니다.
sum 값이 set에 없으면 해당 값을 집합에 추가합니다.
전체 배열을 반복하고 true를 반환하지 않으면 합이 0인 하위 배열이 없다는 의미이므로 false를 반환합니다.
마지막으로 샘플 배열을 사용하여 함수를 테스트하고 결과를 콘솔에 기록합니다.
위 내용은 합이 0인 하위 배열이 있는지 찾는 JavaScript 프로그램의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

이 기사는 브라우저 개발자 도구를 사용하여 효과적인 JavaScript 디버깅, 중단 점 설정, 콘솔 사용 및 성능 분석에 중점을 둡니다.

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

이 기사는 소스 맵을 사용하여 원래 코드에 다시 매핑하여 미니어링 된 JavaScript를 디버그하는 방법을 설명합니다. 소스 맵 활성화, 브레이크 포인트 설정 및 Chrome Devtools 및 Webpack과 같은 도구 사용에 대해 설명합니다.

Console.log 출력의 차이의 근본 원인에 대한 심층적 인 논의. 이 기사에서는 Console.log 함수의 출력 결과의 차이점을 코드에서 분석하고 그에 따른 이유를 설명합니다. � ...

엔트리 레벨 타입 스크립트 자습서를 마스터 한 후에는 TypeScript를 지원하고 JavaScript로 컴파일하는 IDE에서 자신의 코드를 작성할 수 있어야합니다. 이 튜토리얼은 TypeScript의 다양한 데이터 유형으로 뛰어납니다. JavaScript에는 NULL, UNDEFINED, BOOLEAN, 번호, 문자열, 기호 (ES6에 의해 소개 됨) 및 객체의 7 가지 데이터 유형이 있습니다. TypeScript는이 기반으로 더 많은 유형을 정의 하며이 튜토리얼은이 모든 튜토리얼을 자세히 다룹니다. 널 데이터 유형 JavaScript와 마찬가지로 Null in TypeScript
