이 작업은 주어진 이진 트리의 올바른 노드를 인쇄하는 것입니다. 먼저 사용자는 이진 트리를 생성하기 위해 데이터를 삽입한 다음 결과 트리의 올바른 보기를 인쇄합니다.
위 이미지는 노드 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
#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; }
위 프로그램을 실행하면 다음과 같은 출력이 생성됩니다.
rreee위 내용은 C 언어에서는 이진 트리의 오른쪽 보기를 인쇄합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!