• LC 971. Flip Binary Tree To Match Preorder Traversal


    Given a binary tree with N nodes, each node has a different value from {1, ..., N}.

    A node in this binary tree can be flipped by swapping the left child and the right child of that node.

    Consider the sequence of N values reported by a preorder traversal starting from the root.  Call such a sequence of N values the voyage of the tree.

    (Recall that a preorder traversal of a node means we report the current node's value, then preorder-traverse the left child, then preorder-traverse the right child.)

    Our goal is to flip the least number of nodes in the tree so that the voyage of the tree matches the voyage we are given.

    If we can do so, then return a list of the values of all nodes flipped.  You may return the answer in any order.

    If we cannot do so, then return the list [-1].

    Runtime: 4 ms, faster than 99.80% of C++ online submissions for Flip Binary Tree To Match Preorder Traversal.

    //
    // Created by yuxi on 2019-01-18.
    //
    
    #include <vector>
    #include <unordered_map>
    using namespace std;
    
    
    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    private:
      unordered_map<int,int> mp;
    public:
      vector<int> flipMatchVoyage(TreeNode* root, vector<int>& voyage) {
        for(int i=0; i<voyage.size(); i++) mp[voyage[i]] = i;
        vector<int> ret;
        bool flag = helper(ret, root, 0);
        if(!flag) return {-1};
        return ret;
      }
      bool helper(vector<int>& ret, TreeNode* root, int idx){
        if(!root) return true;
        if(mp[root->val] != idx) return false;
        int left = root->left ? mp[root->left->val] : -1;
        int right = root->right ? mp[root->right->val] : -1;
        if((left >= 0 && left < mp[root->val]) || (right >= 0 && right < mp[root->val])) return false;
        if(left == -1 && right == -1) return true;
        else if(left == -1 && right != -1) {
          if(right != idx+1) return false;
          return helper(ret, root->right, mp[root->right->val]);
        }
        else if(left != -1 && right == -1) {
          if(left != idx+1) return false;
          return helper(ret, root->left, mp[root->left->val]);
        }
        else if(left > right) {
          if(right != idx+1) return false;
          ret.push_back(root->val);
          return helper(ret, root->right, idx+1) && helper(ret, root->left, mp[root->left->val]);
        }
        else {
          if(left != idx+1) return false;
          return helper(ret, root->left, idx+1) && helper(ret, root->right, mp[root->right->val]);
        }
        }
    };
  • 相关阅读:
    纯CSS打造的一款简约的灰色下拉菜单
    jQuery实现选项卡Tab菜单滚动
    jQuery写淡入淡出的选项卡TAB菜单
    jquery打造一个会自动播放样子也很经典的选项卡tab
    JS+CSS类似QQ好友/黑名单的树型菜单
    【荐】CSS+JS打造简洁的滑动门TAB
    【荐】jQuery实现有动画淡出的二级折叠菜单
    鼠标经过图片由灰色变彩色
    经典的蓝色JS+CSS下拉菜单
    兄弟们,我用Portal starter kit出现如下问题?
  • 原文地址:https://www.cnblogs.com/ethanhong/p/10301723.html
Copyright © 2020-2023  润新知