腾讯音乐笔试

感觉非常难大概

mid hard hard AC 2道第三题没思路但是dp味儿好浓

// 只含 0,1的串,每次只能将相邻的2个字符同时改成0或1
// 最少问多少次,可以让串的所有字符相等
// s.length <= 1e3
 public int minOperations(String s) {
        // write code here
        return Math.min(cnt(s, 0), cnt(s, 1));
 }

// 将s全部改成x, 最少的操作次数
 public int cnt(String s, int x) {
         int res = 0;
        for (int i = 0; i < s.length(); i++) {
            int j = s.charAt(i) - '0';
            if (j == x)
                continue;
            i++;
            res++;
        }
        return res;
 }
// 求有多少连续子数组的元素乘积 0的个数大于等于x
// 防止结果太大对 1e9 + 7 取模
// a.length <= 1e5,  1 <= a[i],x <= 1e9
public class 连续子数组的数量 {
    static int mod = (int) (1e9 + 7);
    public int getSubarrayNum(ArrayList<Integer> a, int x) {
        // write code here
        // 样例:
        // a =[5,2,3,50,4], x = 2 ===> 6
        // [5,2,3,50,4],[50,4],[3,50,4],[2,3,5,10,4],[2,3,50],[5,2,3,50]
        int[] sum2 = new int[a.size() + 1];
        int[] sum5 = new int[a.size() + 1];
        int res = 0;
        int c2 = 0;
        int c5 = 0;
        for (int i = 0; i < a.size(); i++) {
            int y = a.get(i);

            while (y % 2 == 0) {
                c2++;
                y /= 2;
            }
            while (y % 5 == 0) {
                c5++;
                y /= 5;
            }
            sum2[i + 1] = c2;
            sum5[i + 1] = c5;
            if (Math.min(c2, c5) < x)
                continue;
            int min = Math.min(find(sum2, c2 - x, i), find(sum5, c5 - x, i));
            res = (res + min + 1) % mod;
        }
        return res;
    }

    int find(int[] a, int x, int end) {
        int l = 1, r = end;
        while (l <= r) {
            int mid = l + r >> 1;
            if (a[mid] <= x) {
                l = mid + 1;
            } else {
                r = mid - 1;
            }
        }
        return r;
    }

    public static void main(String[] args) {
        连续子数组的数量 s = new 连续子数组的数量();
        Integer[] a = {5, 2, 3, 50, 4};
        List<Integer> list = Arrays.asList(a);
        int res = s.getSubarrayNum(new ArrayList<>(list), 2);
        System.out.println(res);
    }
}
public class 好矩阵 {
    static int mod = (int) (1e9 + 7);
    // 定义好矩阵:n*m的矩阵中所有2*2的子矩阵的所有元素和为偶数
    // n * m 的矩阵中每个元素都在[1,x],能构造出多少好矩阵
    //   2 <=n,m,x <= 1e9
    public int numsOfGoodMatrix(int n, int m, int x) {
        // write code here
        return -1;
    }
}
#腾讯音乐##腾讯音乐23秋招笔试好难啊,麻了#
全部评论
同学同花顺尝试一下吗,面试简单不造火箭,可保姆式全程跟进度,我帖子有内推
点赞 回复 分享
发布于 2022-09-27 09:30 浙江
除了好矩阵 其他两道大可以不必dp
点赞 回复 分享
发布于 2022-09-26 22:34 北京
第三题
点赞 回复 分享
发布于 2022-09-26 22:16 四川
老哥 第二题这个find方法没太看懂,能给将一下吗
点赞 回复 分享
发布于 2022-09-26 21:24 陕西
你想太复杂了
点赞 回复 分享
发布于 2022-09-26 21:23 广东
情况一模一样
点赞 回复 分享
发布于 2022-09-26 21:03 广东

相关推荐

明明就不饿:看不懂你到底会啥,什么岗位
点赞 评论 收藏
分享
03-13 00:04
已编辑
吉林大学 Java
约面的挺突然。。狠下心接了1.自我介绍2.讲讲JAVA的反射3.可以继续讲讲AOP,动态代理[&nbsp;因为讲反射不小心吟唱到了例如AOP的动态代理,但是这块记忆的非常不熟,结果磕磕绊绊&nbsp;]4.项目我看你写了AOP和注解,具体怎么实现滑动窗口限流的[&nbsp;梦到什么说什么,吟唱八股发散千万不要散到自己不熟悉的区域&nbsp;]5.也讲讲为什么另一个项目选择令牌桶,具体流程6.&nbsp;OK,讲讲&nbsp;Redis&nbsp;的数据类型?还有吗?就了解这五种嘛[&nbsp;把5个的基础类型从应用对比到历届底层全都吟唱了一遍。一句还有吗直接没力气了,简历就写了理解5种,别的我是真一点没看TT&nbsp;]7.讲讲Redission分布式锁实现8.这个指数退避怎么实现的9.在这里有考虑去保障幂等性嘛10.这里为什么使用指数退避呢?&nbsp;什么时候用均匀重传[已经晕过去了说不了解,刚说了后就意识到,估计应该说指数退避能缓解压力防止下游服务器雪崩之类的]11.ok,那讲讲JMM12.讲讲RocketMQ如何保证的不丢消息13.讲讲RocketMQ延迟消息原理14.讲讲项目Redis实现会话记忆这一块15.如果ai调用function&nbsp;calling出现幻觉,有考虑怎么解决吗?[&nbsp;不了解,面试官说什么接口幂等化,高危操作人工防护,没在听,感觉人已经飞升了TT&nbsp;]16.mcp了解嘛?和function&nbsp;calling有什么区别[&nbsp;依旧不了解,只能说了个前者规范架构抽象解耦,后者耦合高只能算个工具调用]17.AI生成代码的代码质量怎么保障,那平时如何review的呢18.算法。lc215&nbsp;&nbsp;数组中最大第k个元素19.打算考研还是本科就业20.反问1️⃣有哪里不足,有哪些需要提高的部分。[主要说知识广度不够,多刷算法,让我别太紧张]2️⃣部门业务会做什么人生第二次面试。感觉大厂面试官的气场压力很大应该凉了不过这次面试非常锻炼心态,多面试,多面试。
冰炸橙汁_不做oj版:redis除了五种基本数据类型,其他的几种还是要掌握一下的,挺常用
点赞 评论 收藏
分享
评论
8
10
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务