来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/NYBBNL 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

给你一棵二叉搜索树,请 按中序遍历 将其重新排列为一棵递增顺序搜索树,使树中最左边的节点成为树的根节点,并且每个节点没有左子节点,只有一个右子节点。

解答

把二叉搜索树展开为升序链表:

  1. 中序遍历是必须的
  2. 执行完左子节点,就把左子节点置为 null,然后把它添加到上一个节点 prev.right 上

    1. /**
    2. * Definition for a binary tree node.
    3. * function TreeNode(val, left, right) {
    4. * this.val = (val===undefined ? 0 : val)
    5. * this.left = (left===undefined ? null : left)
    6. * this.right = (right===undefined ? null : right)
    7. * }
    8. */
    9. /**
    10. * @param {TreeNode} root
    11. * @return {TreeNode}
    12. */
    13. var increasingBST = function(root) {
    14. let head, prev;
    15. function travere (node) {
    16. if (!node) return null;
    17. travere(node.left);
    18. node.left = null;
    19. if (!head) {
    20. head = prev = node;
    21. } else {
    22. prev.right = node;
    23. prev = prev.right;
    24. }
    25. travere(node.right);
    26. }
    27. travere(root);
    28. return head;
    29. };