Untitled

mail@pastecode.io avatar
unknown
plain_text
5 months ago
1.9 kB
2
Indexable
#include <iostream>
#include <vector>
#include <unordered_map>
#include <unordered_set>

using namespace std;

// TreeNode structure
struct TreeNode {
    int val;
    vector<TreeNode*> children;
    TreeNode(int x) : val(x) {}
};

// Function to build the tree from parent-child relationships
TreeNode* buildTree(const vector<int>& nodeValues, const vector<pair<int, int>>& relationships) {
    int n = nodeValues.size();
    vector<TreeNode*> nodes(n);
    
    // Create all nodes
    for (int i = 0; i < n; ++i) {
        nodes[i] = new TreeNode(nodeValues[i]);
    }
    
    // Create tree structure
    for (const auto& rel : relationships) {
        int parentIdx = rel.first;
        int childIdx = rel.second;
        nodes[parentIdx]->children.push_back(nodes[childIdx]);
    }
    
    // Return the root (node 0 is assumed to be the root)
    return nodes[0];
}

// Postorder traversal function
void postorderTraversal(TreeNode* root, vector<int>& result) {
    if (root) {
        for (TreeNode* child : root->children) {
            postorderTraversal(child, result);
        }
        result.push_back(root->val);
    }
}

int main() {
    int n;
    cin >> n;
    
    vector<int> nodeValues(n);
    for (int i = 0; i < n; ++i) {
        cin >> nodeValues[i];
    }
    
    int m;
    cin >> m;
    
    vector<pair<int, int>> relationships(m);
    for (int i = 0; i < m; ++i) {
        int parent, child;
        cin >> parent >> child;
        relationships[i] = {parent, child};
    }
    
    // Build the tree
    TreeNode* root = buildTree(nodeValues, relationships);
    
    // Perform postorder traversal
    vector<int> postorder;
    postorderTraversal(root, postorder);
    
    // Output the postorder traversal
    for (size_t i = 0; i < postorder.size(); ++i) {
        if (i > 0) cout << " ";
        cout << postorder[i];
    }
    cout << endl;
    
    return 0;
}
Leave a Comment