배열 목록을 트리 구조로 변환
이 문제에서는 요소의 평면 배열을 계층적 트리 구조로 변환하는 작업을 맡습니다. 입력 배열은 id, parentid 및 name이라는 세 가지 속성을 가진 객체로 구성됩니다. 출력은 각 노드가 입력 배열의 요소를 나타내고 이에 속하는 하위 노드 목록을 갖는 트리 구조여야 합니다.
이 문제를 해결하려면 중첩 세트와 같은 방법에 의존할 수 없습니다. 데이터베이스 제약. 대신 재귀 알고리즘을 활용하여 트리를 구축합니다.
$arr = array( array('id' => 100, 'parentid' => 0, 'name' => 'a'), array('id' => 101, 'parentid' => 100, 'name' => 'a'), array('id' => 102, 'parentid' => 101, 'name' => 'a'), array('id' => 103, 'parentid' => 101, 'name' => 'a'), ); $new = array(); foreach ($arr as $a) { $new[$a['parentid']][] = $a; } $tree = createTree($new, array($arr[0]));
첫 번째 단계에서는 입력 배열을 반복하고 상위 ID별로 요소를 그룹화하여 각 키가 상위 ID를 나타내는 새 배열을 만듭니다. 이며 값은 해당 하위 항목의 배열입니다. 그런 다음 도우미 함수 createTree를 호출하여 트리를 재귀적으로 생성합니다.
function createTree(&$list, $parent) { $tree = array(); foreach ($parent as $k => $l) { if (isset($list[$l['id']])) { $l['children'] = createTree($list, $list[$l['id']]); } $tree[] = $l; } return $tree; }
createTree 함수는 재구성된 배열 $list와 트리의 현재 수준을 나타내는 배열 $parent라는 두 가지 매개 변수를 사용합니다. 함수 내에서 $parent 배열을 반복하고 $list에 현재 요소에 대한 하위 항목이 포함되어 있는지 검사합니다. 하위 항목이 발견되면 createTree를 반복적으로 호출하여 해당 요소에 대한 하위 트리를 구축하고 이를 현재 요소의 하위 속성으로 추가합니다. 마지막으로, 현재 요소를 $tree 배열에 추가하고 트리를 반환합니다.
이 알고리즘을 따르면 제공된 배열 목록에서 트리 구조를 효율적으로 구성하여 사이의 계층 관계에 대한 중첩 표현을 생성할 수 있습니다. 요소.
위 내용은 평면 배열 목록을 계층적 트리 구조로 효율적으로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

expendencyInphpisaDesignpatternpattern thatenhances-flexibility, testability 및 maintainabilitable externaldenciestoclasses.itallowsforloosecoupling, easiertesting throughmocking 및 modulardesign, berrequirecarefultructuringtoavoid-inje

PHP 성능 최적화는 다음 단계를 통해 달성 할 수 있습니다. 1) 스크립트 상단에 require_once 또는 include_once를 사용하여 파일로드 수를 줄입니다. 2) 데이터베이스 쿼리 수를 줄이기 위해 전처리 문 및 배치 처리를 사용하십시오. 3) Opcode 캐시에 대한 Opcache 구성; 4) PHP-FPM 최적화 프로세스 관리를 활성화하고 구성합니다. 5) CDN을 사용하여 정적 자원을 배포합니다. 6) 코드 성능 분석을 위해 Xdebug 또는 Blackfire를 사용하십시오. 7) 배열과 같은 효율적인 데이터 구조를 선택하십시오. 8) 최적화 실행을위한 모듈 식 코드를 작성하십시오.

opCodeCachingsIntIficInlyIntImeRimproveSphpperformanceCachingCompileDCode, retingServerLoadandResponsEtimes.1) itStoresCompyledPhpCodeInMemory, BYPASSINGPARSINGCOMPILING.2) UseOpCacheSettingParametersInphP.Ini, likeMoryConsAncme AD

종속성 주입은 PHP의 외부 주입을 통해 객체 종속성을 제공하여 코드의 유지 관리 및 유연성을 향상시킵니다. 구현 방법에는 다음이 포함됩니다. 1. 생성자 주입, 2. 값 주입 세트, 3. 인터페이스 주입. 종속성 주입을 사용하면 분리되어 테스트 성과 유연성을 향상시킬 수 있지만 복잡성과 성능 오버 헤드가 증가 할 가능성에주의를 기울여야합니다.

PHP에서 의존성 주입 (DI) 구현은 수동 주입 또는 DI 컨테이너를 사용하여 수행 할 수 있습니다. 1) 수동 주입은 Userservice 클래스 주입 로거와 같은 생성자를 통해 종속성을 통과합니다. 2) DI 컨테이너를 사용하여 컨테이너 클래스와 같은 종속성을 자동으로 관리하여 로거 및 사용자 서비스를 관리합니다. DI를 구현하면 코드 유연성 및 테스트 가능성을 향상시킬 수 있지만 오버 삽입 및 서비스 로케이터 안티 모드와 같은 트랩에주의를 기울여야합니다.

thedifferencebetweenUnset () andsession_destroy () istssection_destroy () thinatesTheentiresession.1) TEREMOVECIFICESSESSION 'STERSESSIVEBLESSESSIVESTIETSTESTERSALLS'SSOVERSOLLS '를 사용하는 것들

stickysessionsureSureSureRequestSaroutEdToTheSERSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESINCENSENCY

phpoffersvarioussessionsaveAndlers : 1) 파일 : 기본, 단순, 단순한 BUTMAYBOTTLENECKONHIGH-TRAFFICSITES.2) MEMCACHED : 고성능, IdealForspeed-CriticalApplications.3) Redis : SimilartomemCached, WithaddedPersistence.4) 데이터베일 : OffforIntegrati


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기