> 일반적인 문제 > 이진 검색 트리란 무엇입니까?

이진 검색 트리란 무엇입니까?

藏色散人
풀어 주다: 2020-06-29 10:03:46
원래의
6674명이 탐색했습니다.

이진 검색 트리는 이진 검색 트리 또는 이진 정렬 트리라고도 하며 연결 ​​목록 데이터 구조로 표현될 수 있으며, 여기서 각 노드는 일반적으로 키입니다. 및 위성 데이터의 경우 각 노드에는 lchild, rchild 및 parent 속성도 포함됩니다.

이진 검색 트리란 무엇입니까?

이진 검색 트리(또는 이진 검색 트리, 이진 정렬 트리) 빈 트리이거나 다음 속성을 갖는 이진 트리입니다. 왼쪽 자식인 경우 트리가 비어 있지 않으면 값 ​왼쪽 하위 트리에 있는 모든 노드의 값이 루트 노드 값보다 작습니다. 오른쪽 하위 트리가 비어 있지 않으면 오른쪽 하위 트리에 있는 모든 노드의 값이 왼쪽 및 오른쪽 루트 노드 값보다 큽니다. 하위 트리는 각각 이진 정렬 트리이기도 합니다. 이진 검색 트리는 고전적인 데이터 구조로서 연결 리스트의 빠른 삽입 및 삭제 작업과 빠른 배열 검색이라는 장점을 가지고 있어 일반적으로 파일 시스템 및 데이터베이스에서 사용됩니다. 데이터 구조는 효율적인 정렬 및 검색 작업을 수행합니다.

원리

이진 검색 트리(BST)는 이진 검색 트리 또는 이진 정렬 트리라고도 합니다. 이진 검색 트리는 이진 트리로 구성되며 각 노드가 객체인 연결 리스트 데이터 구조로 표현될 수 있습니다. 일반적으로 각 노드에는 키 및 위성 데이터 외에도 노드의 왼쪽 자식, 오른쪽 자식 및 부모(부모 노드)를 각각 가리키는 lchild, rchild 및 parent 속성도 포함되어 있습니다. 하위 노드 또는 상위 노드가 존재하지 않는 경우 해당 속성의 값은 NIL입니다. 루트 노드는 트리에서 부모 포인터가 NIL인 유일한 노드이고 리프 노드의 자식 노드 포인터도 NIL입니다.

구조

이진 검색 트리는 다음 작업을 효율적으로 수행할 수 있는 데이터 구조입니다.

1. 값 삽입

2. 특정 값이 포함되어 있는지 쿼리

3.

위 내용은 이진 검색 트리란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿