> 백엔드 개발 > C++ > C 언어에서는 이진 트리의 오른쪽 보기를 인쇄합니다.

C 언어에서는 이진 트리의 오른쪽 보기를 인쇄합니다.

WBOY
풀어 주다: 2023-09-16 23:13:01
앞으로
767명이 탐색했습니다.

이 작업은 주어진 이진 트리의 올바른 노드를 인쇄하는 것입니다. 먼저 사용자는 이진 트리를 생성하기 위해 데이터를 삽입한 다음 결과 트리의 올바른 보기를 인쇄합니다.

C 언어에서는 이진 트리의 오른쪽 보기를 인쇄합니다.

위 이미지는 노드 10, 42, 93, 14, 35, 96, 57 및 88을 사용하여 생성된 이진 트리를 보여 주며, 트리 오른쪽의 노드가 선택되어 표시됩니다. 예를 들어 10, 93, 57, 88은 이진 트리의 가장 오른쪽 노드입니다.

Input : 10 42 93 14 35 96 57 88
Output : 10 93 57 88
로그인 후 복사

각 노드에는 왼쪽 포인터와 오른쪽 포인터라는 두 개의 포인터가 있습니다. 이 질문에 따르면 프로그램은 올바른 노드만 통과하면 됩니다. 따라서 노드의 왼쪽 자식을 고려할 필요가 없습니다.

오른쪽 뷰는 해당 레벨의 마지막 노드인 모든 노드를 저장합니다. 따라서 오른쪽 하위 트리를 먼저 순회한 다음 왼쪽 하위 트리를 순회하는 방식으로 간단히 재귀적 방법을 사용하여 노드를 저장하고 액세스할 수 있습니다. 프로그램이 노드의 레벨이 이전 노드의 레벨보다 높다는 것을 감지할 때마다 이전 노드가 해당 레벨의 마지막 노드가 되기 때문에 표시됩니다.

아래 코드는 주어진 알고리즘의 C 언어 구현을 보여줍니다.

알고리즘

START
   Step 1 -> create node variable of type structure
      Declare int data
      Declare pointer of type node using *left, *right
   Step 2 -> create function for inserting node with parameter as item
      Declare temp variable of node using malloc
      Set temp->data = item
      Set temp->left = temp->right = NULL
      return temp
   step 3 -> Declare Function void right_view(struct node *root, int level, int *end_level)
      IF root = NULL
         Return
      IF *end_level < level
         Print root->data
         Set *end_level = level
         Call right_view(root->right, level+1, end_level)
         Call right_view(root->left, level+1, end_level)
   Step 4 -> Declare Function void right(struct node *root)
      Set int level = 0
      Call right_view(root, 1, &level)
   Step 5 -> In Main()
      Pass the values for the tree nodes using struct node *root = New(10)
      Call right(root)
STOP
로그인 후 복사

Example

의 중국어 번역은 다음과 같습니다.

Example

#include<stdio.h>
#include<stdlib.h>
struct node {
   int data;
   struct node *left, *right;
};
struct node *New(int item) {
   struct node *temp = (struct node *)malloc(sizeof(struct node));
   temp->data = item;
   temp->left = temp->right = NULL;
   return temp;
}
void right_view(struct node *root, int level, int *end_level) {
   if (root == NULL) return;
   if (*end_level < level) {
      printf("%d\t", root->data);
      *end_level = level;
   }
   right_view(root->right, level+1, end_level);
   right_view(root->left, level+1, end_level);
}
void right(struct node *root) {
   int level = 0;
   right_view(root, 1, &level);
}
int main() {
   printf("right view of a binary tree is : ");
   struct node *root = New(10);
   root->left = New(42);
   root->right = New(93);
   root->left->left = New(14);
   root->left->right = New(35);
   root->right->left = New(96);
   root->right->right = New(57);
   root->right->left->right = New(88);
   right(root);
   return 0;
}
로그인 후 복사

Output

위 프로그램을 실행하면 다음과 같은 출력이 생성됩니다.

rreee

위 내용은 C 언어에서는 이진 트리의 오른쪽 보기를 인쇄합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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