竞赛题-6235. 逐层排序二叉树所需的最少操作数目

#头条创作挑战赛#

题目:

给你一个 值互不相同 的二叉树的根节点 root

在一步操作中,你可以选择 同一层 上任意两个节点,交换这两个节点的值。

返回每一层按 严格递增顺序 排序所需的最少操作数目。

节点的 层数 是该节点和根节点之间的路径的边数。

示例 1 :

image.png


输入:root = [1,4,3,7,6,8,5,null,null,null,null,9,null,10]
输出:3
解释:

示例 2 :

image.png

输入:root = [1,3,2,7,6,5,4]
输出:3
解释:

image.png



输入:root = [1,2,3,4,5,6]
输出:0
解释:每一层已经按递增顺序排序,所以返回 0 。

提示:

思路:

先进行树的层次遍历,再看每一层需要交换的次数。 交换次数的计算可以用一个排好序的数组ordered和一个map. map记录原始树层次上的数的位置。

java代码:

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public int minimumOperations(TreeNode root) {
        if (root == null) {
            return 0;
        }

        int res = 0;
        Queue queue = new LinkedList();
        queue.offer(root);
        while (!queue.isEmpty()) {
            int size = queue.size();
            int[] temp = new int[size];
            for (int i = 0; i < size; i++) {
                TreeNode node = queue.poll();
                temp[i] = node.val;

                if (node.left != null) {
                    queue.offer(node.left);
                }
                if (node.right != null) {
                    queue.offer(node.right);
                }
            }
            res += exchangeTime(temp);
        }

        return res;

    }

    private int exchangeTime(int[] temp) {
        int size = temp.length;
        if (size <= 1) {
            return 0;
        }

        int[] ordered = new int[size];
        System.arraycopy(temp, 0, ordered, 0, size);
        Arrays.sort(ordered);

        Map map = new HashMap(size);
        for (int i = 0; i < size; i++) {
            map.put(temp[i], i);
        }

        int res = 0;
        for (int i = 0; i < size; i++) {
            if (ordered[i] != temp[i]) {
                res++;
                exchange(temp, map, map.get(ordered[i]), i);
            }
        }
        return res;
    }

    private void exchange(int[] temp, Map map, Integer j, int i) {
        int t = temp[j];
        temp[j] = temp[i];
        temp[i] = t;
        map.put(temp[j], j);
        map.put(temp[i], i);
    }
}
展开阅读全文

页面更新:2024-04-22

标签:数目   操作   遍历   挑战赛   数组   节点   示例   顺序   层次   次数   竞赛题

1 2 3 4 5

上滑加载更多 ↓
推荐阅读:
友情链接:
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2008-2024 All Rights Reserved. Powered By bs178.com 闽ICP备11008920号-3
闽公网安备35020302034844号

Top