이진 트리의 연결 저장 구조는 연결 리스트를 사용하여 이진 트리를 표현하는 것을 의미합니다. 즉, 연결 리스트를 사용하여 요소 간의 논리적 관계를 나타냅니다. 이진 트리의 연결 저장 구조는 일반적으로 이진 연결 목록과 삼중 연결 목록의 두 가지 저장 형식을 갖습니다.
이 튜토리얼의 운영 환경: Windows 7 시스템, c99 버전, Dell G3 컴퓨터.
이진 트리의 연결 저장 구조는 연결 리스트를 사용하여 이진 트리를 나타냅니다. 즉, 연결 리스트를 사용하여 요소 간의 논리적 관계를 나타냅니다. 일반적으로 두 가지 저장 형식이 있습니다.
연결된 목록의 각 노드는 세 개의 필드로 구성됩니다. 데이터 필드 외에도 노드의 왼쪽 자식과 오른쪽 자식을 제공하는 데 사용되는 두 개의 포인터 필드가 있습니다. 해당 위치의 저장 주소입니다.
연결된 목록의 각 노드는 데이터 필드 외에도 노드의 왼쪽 자식, 오른쪽 자식 및 부모 노드의 저장 주소를 제공하는 데 사용되는 3개의 포인터 필드로 구성됩니다.
이진 트리의 연쇄 저장 구조(C 언어로 자세히 설명)
그림 1 일반 이진 트리의 개략도
그림 1과 같이 일반 이진 트리입니다. 연결되어 있는 경우 저장하려면 트리의 루트 노드에서 시작하여 각 노드와 왼쪽 및 오른쪽 자식을 연결 목록에 저장하기만 하면 됩니다. 따라서 그림 1에 해당하는 체인 저장 구조는 그림 2와 같습니다.
그림 2 이진 트리의 체인 저장 구조의 도식 다이어그램
그림 2에서 볼 수 있듯이 이진 트리의 체인 저장을 사용할 때 노드 구조는 세 부분으로 구성됩니다(그림 3 참조).
포인터 왼쪽 하위 노드(Lchild) ;
노드에 저장된 데이터(data);
오른쪽 하위 노드(Rchild)에 대한 포인터;
그림 3 바이너리 트리 노드 구조
노드 구조를 나타내는 C 언어 코드는
typedef struct BiTNode{ TElemType data;//数据域 struct BiTNode *lchild,*rchild;//左右孩子指针 struct BiTNode *parent; }BiTNode,*BiTree;
그림 2의 체인 저장 구조에 해당하는 C 언어 코드는
#include <stdio.h> #include <stdlib.h> #define TElemType int typedef struct BiTNode{ TElemType data;//数据域 struct BiTNode *lchild,*rchild;//左右孩子指针 }BiTNode,*BiTree; void CreateBiTree(BiTree *T){ *T=(BiTNode*)malloc(sizeof(BiTNode)); (*T)->data=1; (*T)->lchild=(BiTNode*)malloc(sizeof(BiTNode)); (*T)->lchild->data=2; (*T)->rchild=(BiTNode*)malloc(sizeof(BiTNode)); (*T)->rchild->data=3; (*T)->rchild->lchild=NULL; (*T)->rchild->rchild=NULL; (*T)->lchild->lchild=(BiTNode*)malloc(sizeof(BiTNode)); (*T)->lchild->lchild->data=4; (*T)->lchild->rchild=NULL; (*T)->lchild->lchild->lchild=NULL; (*T)->lchild->lchild->rchild=NULL; } int main() { BiTree Tree; CreateBiTree(&Tree); printf("%d",Tree->lchild->lchild->data); return 0; }
프로그램 출력 결과:
4
실제로는 이진 트리 체인 그림 2에 표시된 것보다 더 많은 저장 구조가 있습니다. 예를 들어, 일부 실제 시나리오에서는 "노드의 부모 노드 찾기" 작업이 수행될 수 있습니다. 이 경우 그림과 같이 각 노드의 부모 노드를 가리키도록 노드 구조에 포인터 필드를 추가할 수 있습니다. 그림 4. :
그림 4 사용자 정의 이진 트리의 연결된 저장 구조
이러한 연결 목록 구조를 일반적으로 삼항 연결 목록이라고 합니다.
그림 4에 표시된 세 갈래 연결 목록을 사용하면 각 노드의 상위 노드를 쉽게 찾을 수 있습니다. 따라서 실제 문제를 해결할 때 적절한 연결 목록 구조를 사용하여 이진 트리를 저장하면 절반의 노력으로 두 배의 결과를 얻을 수 있습니다.
관련 추천: "C 언어 비디오 튜토리얼"
위 내용은 이진 트리의 연결 저장 구조는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

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