배열에 있는 연결 목록에서 노드 삭제
3217. 배열에 있는 연결 목록에서 노드 삭제
난이도:중
주제: 배열, 해시 테이블, 연결 목록
정수 배열과 연결 목록의 헤드가 제공됩니다. 연결 리스트에서 nums에 존재하는 값을 가진 모든 노드를 제거한 후 수정된 연결 리스트의 헤드를 반환합니다.
예 1:
- 입력: nums = [1,2,3], head = [1,2,3,4,5]
- 출력: [4,5]
-
설명:
값이 1, 2, 3인 노드를 제거합니다.
예 2:
- 입력: 입력: nums = [1], head = [1,2,1,2,1,2]
- 출력: [2,2,2]
-
설명:
값이 1인 노드를 제거합니다.
예 3:
- 입력: nums = [5], head = [1,2,3,4]
-
출력: [1,2,3,4]
값이 5인 노드는 없습니다.
제약조건:
- 1 <= nums.length <= 105
- 1 <= 숫자[i] <= 105
- nums의 모든 요소는 고유합니다.
- 주어진 목록의 노드 수는 [1, 105] 범위에 있습니다.
- 1 <= Node.val <= 105
- 연결된 목록에 nums에 없는 값을 가진 노드가 하나 이상 있도록 입력이 생성됩니다.
힌트:
- 숫자의 모든 요소를 세트에 추가합니다.
- 목록을 스캔하여 설정을 확인하여 현재 요소를 삭제해야 하는지 확인하세요.
해결책:
연결된 목록을 탐색하여 nums 배열에 값이 있는 모든 노드를 제거해야 합니다.
접근하다:
- 빠른 조회를 위한 해시 세트: nums에 값이 있는지 확인하는 것이 효율적이어야 하므로 nums를 해시 세트로 변환하겠습니다. 이를 통해 각 값에 대해 O(1) 조회가 가능합니다.
- 연결된 목록을 통해 반복: 연결된 목록을 반복하고 해시 세트에 값이 있는 노드를 제거합니다.
- 포인터 조작: 반복하는 동안 nums 배열의 값과 일치하는 노드를 "건너뛰기" 위해 포인터를 조정합니다.
단계:
- 숫자를 O(1) 조회를 위한 해시 세트로 변환합니다.
- 두 개의 포인터를 사용하여 연결 목록을 탐색합니다. 하나는 현재 노드용이고 다른 하나는 이전 노드용이므로 노드를 효율적으로 제거하는 데 도움이 됩니다.
- 각 노드에 대해 해당 값이 해시 세트에 있는지 확인하세요. 그렇다면 이전 노드의 다음을 업데이트하여 현재 노드를 건너뜁니다.
이 솔루션을 PHP로 구현해 보겠습니다: 3217. 배열에 있는 연결 목록에서 노드 삭제
val = $val; $this->next = $next; } } class Solution { /** * @param Integer[] $nums * @param ListNode $head * @return ListNode */ function removeElements($head, $nums) { ... ... ... /** * go to ./solution.php */ } } // Example usage: // Linked List: 1 -> 2 -> 3 -> 4 -> 5 $head = new ListNode(1); $head->next = new ListNode(2); $head->next->next = new ListNode(3); $head->next->next->next = new ListNode(4); $head->next->next->next->next = new ListNode(5); // Array nums: [1, 2, 3] $nums = [1, 2, 3]; $solution = new Solution(); $result = $solution->removeElements($head, $nums); // Function to print the linked list function printList($node) { while ($node !== null) { echo $node->val . " "; $node = $node->next; } } // Print the resulting linked list printList($result); // Output: 4 5 ?>설명:
removeElements($head, $nums):
- 빠른 조회를 위해 먼저 숫자를 해시 세트($numSet = array_flip($nums);)로 변환합니다.
- 더미 노드가 생성되어 목록의 선두에 연결됩니다. 이는 헤드 노드 제거와 같은 극단적인 경우를 단순화하는 데 도움이 됩니다.
- 이전 포인터는 현재 노드 이전의 노드를 추적하므로 목록에서 현재 노드를 건너뛰어 제거할 수 있습니다.
- 각 노드에 대해 해당 값이 numSet에 있는지 확인합니다. 그렇다면 현재 노드를 건너뛰도록 prev->next 포인터를 조정하여 제거합니다.
최첨단 케이스:
- 헤드 노드를 제거해야 하는 경우 더미 노드는 헤드가 깔끔하게 제거되고 올바른 목록을 반환할 수 있도록 보장합니다.
- 연속된 여러 노드를 제거해야 하는 경우를 처리합니다.
복잡성:
- 시간 복잡도: O(n), 여기서 n은 연결 목록의 노드 수입니다. 우리는 각 노드를 한 번씩 방문합니다. 숫자를 집합으로 변환하는 데는 O(m)이 소요됩니다. 여기서 m은 숫자의 크기입니다.
- 공간 복잡도: 숫자 집합을 저장하는 데는 O(m)입니다.
예제 연습:
입력 숫자 = [1, 2, 3] 및 헤드 = [1, 2, 3, 4, 5]의 경우 알고리즘은 다음을 수행합니다.
- 노드 1에서 시작하여 1이 숫자인지 확인한 후 제거하세요.
- 노드 2로 이동하여 2가 숫자인지 확인한 후 제거하세요.
- 노드 3으로 이동하여 3이 숫자인지 확인한 후 제거하세요.
- 숫자가 아닌 노드 4, 5로 이동하여 목록에 남습니다.
결과 연결 리스트는 [4, 5]입니다.
연락처 링크
이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!
이런 유용한 콘텐츠를 더 원하시면 저를 팔로우해주세요.
- 링크드인
- 깃허브
위 내용은 배열에 있는 연결 목록에서 노드 삭제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

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

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

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

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

PHP 변수 범위에 대한 일반적인 문제 및 솔루션에는 다음이 포함됩니다. 1. 기능 내에서 글로벌 변수에 액세스 할 수 없으며 글로벌 키워드 또는 매개 변수를 사용하여 전달해야합니다. 2. 정적 변수는 정적으로 선언되며 한 번만 초기화되며 값은 여러 통화 사이에 유지됩니다. 3. $ _get 및 $ _post와 같은 Hyperglobal 변수는 모든 범위에서 직접 사용할 수 있지만 안전한 필터링에주의를 기울여야합니다. 4. 익명 함수 사용 키워드를 통해 상위 범위 변수를 도입해야하며 외부 변수를 수정할 때는 참조를 전달해야합니다. 이러한 규칙을 마스터하면 오류를 피하고 코드 안정성을 향상시키는 데 도움이 될 수 있습니다.

PHP 파일 업로드를 안전하게 처리하려면 소스 및 유형을 확인하고 파일 이름 및 경로를 제어하고 서버 제한을 설정하고 미디어 파일을 두 번 처리해야합니다. 1. 토큰을 통한 CSRF를 방지하기 위해 업로드 소스를 확인하고 화이트리스트 제어를 사용하여 FINFO_FILE을 통해 실제 MIME 유형을 감지합니다. 2. 파일의 이름을 임의의 문자열로 바꾸고 감지 유형에 따라 비 WEB 디렉토리에 저장할 확장자를 결정하십시오. 3. PHP 구성 업로드 크기 및 임시 디렉토리 NGINX/APACHE는 업로드 디렉토리에 대한 액세스를 금지합니다. 4. GD 라이브러리는 잠재적 인 악성 데이터를 지우기 위해 그림을 다시 찾습니다.

PHP 주석 코드에는 세 가지 일반적인 방법이 있습니다. 1. // 또는 #을 사용하여 한 줄의 코드를 차단하며 // 사용하는 것이 좋습니다. 2. 사용 /.../ 여러 줄로 코드 블록을 랩핑하려면 중첩 할 수는 없지만 교차 할 수 있습니다. 3. 복합 기술 사용 / if () {} /와 같은 논리 블록을 제어하거나 편집기 바로 가기 키를 사용한 효율성을 향상시키기 위해서는 기호를 닫는 데주의를 기울이고 사용할 때 중첩을 피해야합니다.

Ageneratorinphpisamemory- 효율적인 Way-Erate-Overgedatasetsetsbaluesoneatimeatimeatimeatimallatonce.1.generatorsuseTheyieldKeywordTocroadtOpvaluesondemand, RetingMemoryUsage.2

PHP 의견을 작성하는 열쇠는 목적과 사양을 명확히하는 것입니다. 의견은 중복성이나 너무 단순성을 피하고 "수행 된 것"보다는 "왜"를 설명해야합니다. 1. 클래스 및 메소드 설명에 DocBlock (/*/)과 같은 통합 형식을 사용하여 가독성 및 도구 호환성을 향상시킵니다. 2. JS 점프가 수동으로 출력 해야하는 이유와 같은 논리의 이유를 강조합니다. 3. 복잡한 코드 전에 개요 설명을 추가하고 프로세스를 단계적으로 설명하고 전체 아이디어를 이해하는 데 도움이됩니다. 4. Todo 및 Fixme를 합리적으로 사용하여 할 일 항목과 문제를 표시하여 후속 추적 및 협업을 용이하게합니다. 주석이 양호하면 통신 비용을 줄이고 코드 유지 보수 효율성을 향상시킬 수 있습니다.

tolearnpheffectical, startBysetTupaloCalserErverEnmentUsingToolslikexamppandacodeeditor -likevscode.1) installxamppforapache, mysql, andphp.2) useacodeeditorforsyntaxsupport.3)) 3) testimplephpfile.next, withpluclucincludechlucincluclucludechluclucled

toinstallphpquickly, usexampponwindowsorhomebrewonmacos.1. 온수, downloadandinstallxAmpp, selectComponents, startApache 및 placefilesinhtdocs.2

PHP에서는 정사각형 브래킷 또는 곱슬 브레이스를 사용하여 문자열 특정 인덱스 문자를 얻을 수 있지만 사각형 브래킷을 권장합니다. 인덱스는 0에서 시작하고 범위 외부의 액세스는 널 값을 반환하며 값을 할당 할 수 없습니다. MB_SUBSTR는 다중 바이트 문자를 처리해야합니다. 예 : $ str = "hello"; echo $ str [0]; 출력 H; 그리고 MB_SUBSTR ($ str, 1,1)과 같은 한자는 올바른 결과를 얻어야합니다. 실제 애플리케이션에서 문자열의 길이는 루핑하기 전에 유효성에 대해 동적 문자열을 확인해야하며 다국어 프로젝트는 다중 바이트 보안 기능을 균일하게 사용하는 것이 좋습니다.
