9月8号腾讯音乐后端笔试

今天感觉自己状态不错,难得全a一次,记录一下,
 class Solution {
    // 第一题

    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * <p>
     * 返回满足题意的最小操作数
     *
     * @param str string字符串 给定字符串
     * @return int整型
     */
    public int minOperations(String str) {
        // write code here
        char[] arr = str.toCharArray();
        int[] map = new int[128];
        int n = arr.length;
        int count = 26;
        for (int i = 0; i < n; i++) {
            if (map[arr[i] - 'a'] == 0) {
                count--;
            }
            map[arr[i] - 'a']++;
        }
        int res = 0;
        for (int i = 'a'; i <= 'z'; i++) {
            if (map[i - 'a'] >= 2) {
                while (count > 0 && map[i - 'a'] > 2) {
                    map[i - 'a'] -= 2;
                    count--;
                    res++;
                }
            }
        }

        if (count > 0) {
            for (int i = 0; i < 128; i++) {
                res += (map[i]) / 2;
            }
        } else {
            for (int i = 0; i < 128; i++) {
                if (map[i] != 0) {
                    res += map[i] - 1;
                }
            }
        }
        return res;
    }

    // 第二题

    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * @param preOrder int整型ArrayList
     * @param inOrder  int整型ArrayList
     * @return TreeNode类ArrayList
     */
    public ArrayList<TreeNode> getBinaryTrees(ArrayList<Integer> preOrder, ArrayList<Integer> inOrder) {
        // write code here
        return buildTree(preOrder, 0, preOrder.size() - 1,
                inOrder, 0, inOrder.size() - 1);

    }

    ArrayList<TreeNode> buildTree(ArrayList<Integer> preOrder, int preStart, int preEnd,
                                  ArrayList<Integer> inOrder, int inStart, int inEnd) {
        ArrayList<TreeNode> res = new ArrayList<>();
        if (preStart > preEnd || inStart > inEnd) {
            res.add(null);
            return res;
        }
        int rootVal = preOrder.get(preStart);
        ArrayList<Integer> indexs = new ArrayList<>();
        for (int i = inStart; i <= inEnd; i++) {
            if (inOrder.get(i) == rootVal) {
                indexs.add(i);
            }
        }
        for (Integer index : indexs) {
            ArrayList<TreeNode> lefts = buildTree(preOrder, preStart + 1, preStart + index - inStart,
                    inOrder, inStart, index - 1);
            ArrayList<TreeNode> rights = buildTree(preOrder, preStart + index - inStart + 1, preEnd,
                    inOrder, index + 1, inEnd);
            for (TreeNode left : lefts) {
                for (TreeNode right : rights) {
                    TreeNode root = new TreeNode(rootVal);
                    root.left = left;
                    root.right = right;
                    res.add(root);
                }
            }
        }
        return res;
    }

    // 第三题

    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * @param tree TreeNode类
     * @return int整型
     */
    public int getTreeSum(TreeNode tree) {
        // write code here
        return (int) (traverse(tree) % ((Math.pow(10, 9) + 7)));
    }

    long traverse(TreeNode root) {
        if (root == null) return 0;
        long leftVal = traverse(root.left);
        long rightVal = traverse(root.right);
        return 1 + Math.max(leftVal, rightVal) * 2;
    }
    
}
class TreeNode {
    int val = 0;
    TreeNode left = null;
    TreeNode right = null;

    public TreeNode(int val) {
        this.val = val;
    }
}

#腾讯音乐##腾讯音乐2023秋招笔试心得体会#
全部评论
第三题代码和你一样,就是只过25%
3 回复 分享
发布于 2022-09-08 20:45 湖北
妈的第三题其实我的思路已经对了,但是我是在递归返回的时候就先取余了。。。一直卡着搞得也没有心情做其他题。
点赞 回复 分享
发布于 2022-09-08 20:46 广东
第三题一直卡55,无语
点赞 回复 分享
发布于 2022-09-08 20:47 广东
您好,请问为什么返回值的时候要加1
点赞 回复 分享
发布于 2022-09-08 20:58 北京
第一题思路差不多,只有60%,对比了,还是想不明白。
点赞 回复 分享
发布于 2022-09-08 21:28 安徽
大佬第一题可以写个思路吗
点赞 回复 分享
发布于 2022-09-08 21:42 广东
第三题这样写不怕long也溢出吗,应该是每一层return都模一下严谨一点
点赞 回复 分享
发布于 2022-09-08 22:24 北京
100 100 40不知道有没有面试机会🤣
点赞 回复 分享
发布于 2022-09-09 15:49 安徽
大佬,我想问一下,第一题为什么new int[128]??
点赞 回复 分享
发布于 2022-09-10 19:12 河北
大佬,我想请问一下:   for (TreeNode left : lefts) {                 for (TreeNode right : rights) {                     TreeNode root = new TreeNode(rootVal);                     root.left = left;                     root.right = right;                     res.add(root);                 }             } 这个地方是双重循环,那么最后这个只有一个left节点,确对应了整个rights数组,,我不太懂哎,求大佬解惑哎,而且最后返回应该时一个数组中有多个数组把?啊,我就是个菜鸡
点赞 回复 分享
发布于 2022-09-10 20:33 河北
🐂
点赞 回复 分享
发布于 2022-09-11 16:59 山东
第一题看不懂可以解释一下吗
点赞 回复 分享
发布于 2022-09-11 20:10 浙江

相关推荐

头像
11-09 12:17
清华大学 C++
out11Man:小丑罢了,不用理会
点赞 评论 收藏
分享
11-18 09:44
Java
小白也想要offer:简历别放洋屁,搞不还还放错了,当然你投外企除外,以上纯属个人观点
点赞 评论 收藏
分享
评论
15
55
分享
牛客网
牛客企业服务