Trong hướng dẫn này, chúng ta sẽ thảo luận về một chương trình để chuyển đổi biểu thức bậc ba sang cây nhị phân.
Đối với điều này, chúng tôi sẽ được cung cấp với một biểu thức bậc ba. Nhiệm vụ của chúng ta là chuyển đổi biểu thức đã cho dưới dạng cây nhị phân tùy thuộc vào các đường dẫn (lựa chọn) khác nhau có thể.
Ví dụ
#include<bits/stdc++.h> using namespace std; //node structure of tree struct Node { char data; Node *left, *right; }; //creation of new node Node *newNode(char Data){ Node *new_node = new Node; new_node->data = Data; new_node->left = new_node->right = NULL; return new_node; } //converting ternary expression into binary tree Node *convertExpression(string str, int & i){ //storing current character Node * root =newNode(str[i]); //if last character, return base case if(i==str.length()-1) return root; i++; //if the next character is '?', //then there will be subtree for the current node if(str[i]=='?'){ //skipping the '?' i++; root->left = convertExpression(str,i); //skipping the ':' character i++; root->right = convertExpression(str,i); return root; } else return root; } //printing the binary tree void display_tree( Node *root){ if (!root) return ; cout << root->data <<" "; display_tree(root->left); display_tree(root->right); } int main(){ string expression = "a?b?c:d:e"; int i=0; Node *root = convertExpression(expression, i); display_tree(root) ; return 0; }
Đầu ra
a b c d e