文章目录
- 题目
- 方法一:前序遍历(构造集合) + 集合(构造新树)
- 方法二:原地构建
- 方法三:前序遍历--迭代(构造集合) + 集合(构造新树)
题目
方法一:前序遍历(构造集合) + 集合(构造新树)
List<TreeNode> res = new ArrayList<>();public void flatten(TreeNode root) {dfs(root);for(int i = 0 ; i <res.size() ; i++){if(i == res.size()-1){res.get(i).left = null;res.get(i).right = null;break;}res.get(i).left = null;res.get(i).right = res.get(i+1);}}public void dfs(TreeNode root) {if(root == null ) return ;res.add(root);dfs(root.left);dfs(root.right);}
方法二:原地构建
- 将左子树插入到右子树的地方
- 将原来的右子树接到左子树的最右边节点
- 考虑新的右子树的根节点,一直重复上边的过程,直到新的右子树为 null
public void flatten(TreeNode root) {while(root !=null){if (root.left == null) {root = root.right;} else {TreeNode pre = root.left;while(pre.right !=null){pre =pre.right;}pre.right = root.right;root.right = root.left;root.left = null;root = root.right;}}}
方法三:前序遍历–迭代(构造集合) + 集合(构造新树)
public void flatten(TreeNode root) {List<TreeNode> res = new ArrayList<>();Deque<TreeNode> stack = new LinkedList<>();while(!stack.isEmpty() || root != null){while(root != null) {res.add(root);stack.push(root);root = root.left;}root = stack.pop();root = root.right;}for(int i = 0 ; i <res.size() ; i++){if(i == res.size()-1){res.get(i).left = null;res.get(i).right = null;break;}res.get(i).left = null;res.get(i).right = res.get(i+1);}}