小红书笔试 08.28 AC

小红书选择题真的变态,C++、Java、Python、Go 语言都有,招全才呢。

第一题

    public static void main1(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt(), m = sc.nextInt(), id = sc.nextInt();
        PriorityQueue<int[]> pq = new PriorityQueue<>((a, b) -> a[0] == b[0]? a[1]-b[1]:b[0]-a[0]);
        for(int i = 0; i < n; i++){
            int cnt = 0;
            for(int j = 0; j < m; j++) {
                cnt+= sc.nextInt();
            }
            pq.add(new int[]{cnt, i+1});
        }
        int cnt = 0;
        while(!pq.isEmpty()){
            cnt++;
            int tmp[] = pq.poll();
            if(tmp[1] == id) {
                System.out.println(cnt);
            }
        }
    }


第二题

    public static void main2(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        long k = sc.nextLong();
        long arr[] = new long[n];
        for(int i = 0; i < n; i++){
            arr[i] = sc.nextLong();
        }
        Arrays.sort(arr);
        long ret = 0;
        for(int i = 0; i < n-1; i++){
            long value = arr[i];
            int left = i+1, right = n-1;
            while(left < right) {
                int mid = (left+right)/2;
                if(value * arr[mid] >= k) {
                    right = mid;
                }else{
                    left = mid+1;
                }
            }
            if(value * arr[left] >= k){
                ret += n - left;
            }
        }
        System.out.println(ret*2);
    }


第三题

map 用于记忆,避免重复计算;
dfs 方法用于仿照树进行深搜,其中pre用于记录当前节点的父节点,canuse 用来表示当前节点是否可用。

如果当前节点不可用,则子节点均可用;
如果当前节点均可用,则(1)子节点均可用(2)当前节点和其中一个子节点建立连接,该子节点不可用,其余子节点可用。

有没有更简单的方法呀,感觉还是有点麻烦

   static Map<Integer, Integer> map;
    static ArrayList<Integer>[] edges;
    static int n;
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        n = sc.nextInt();
        map = new HashMap<>();
        edges = new ArrayList[n+3];
        for(int i = 0; i < n+3; i++) {
            edges[i] = new ArrayList<Integer>();
        }
        for(int i = 0; i < n-1; i++) {
            int tmp = sc.nextInt();
            edges[tmp].add(i+2);
            edges[i+2].add(tmp);
        }
        System.out.println(dfs(1, 1, -1));
    }

    static int dfs(int canuse, int idx, int pre) {
        int arr = idx * canuse;
        if (map.containsKey(arr)) {
            return map.get(arr);
        }
        int cnt = 0;
        for (int next : edges[idx]) {
            if (next != pre) {
                cnt += dfs(1, next, idx);
            }
        }
        int ret = cnt;
        if (canuse == 1) {
            for(int next: edges[idx]) {
                if(next != pre) {
                    int f = dfs(-1, next, idx);
                    int t = dfs(1, next, idx);
                    ret = Math.max(ret, cnt - t + f + 1);
                }
            }
        }
        map.put(arr, ret);
        return ret;
    }



#小红书##笔试##校招##23届秋招笔面经#
全部评论
第三题永远找孤立点就行了
2 回复 分享
发布于 2022-08-28 20:30 上海
据说hc只有两个
4 回复 分享
发布于 2022-08-29 11:07 重庆
python不会,C++忘了很多,就只有Java和go能搞一下了
2 回复 分享
发布于 2022-08-28 18:00 上海
第二题感觉好奇怪 我想着先写个双重循环 暴力 没想到直接过了……
8 回复 分享
发布于 2022-08-28 19:10 陕西
选择题就没几道会的,算法题ak了不知道能进面不
点赞 回复 分享
发布于 2022-08-28 18:15 北京
你好想问一下,问什么DFS里求最大值的时候是Math.max(ret, cnt - t + f + 1); 呢,希望大佬解答,感谢
1 回复 分享
发布于 2022-08-29 16:49 辽宁
第三题dfs+树形dp
点赞 回复 分享
发布于 2022-08-28 18:16 浙江
我服了,我也走了
3 回复 分享
发布于 2022-08-28 17:48 河南
大佬求发第三题
2 回复 分享
发布于 2022-08-28 18:01 天津
第三题 拓扑排序,课程表变形
1 回复 分享
发布于 2022-08-29 12:21 陕西
第三题二分图匹配,用匈牙利算法写
1 回复 分享
发布于 2022-08-29 11:09 陕西
第二题暴力二分直接过了。第三题想着每次只选叶子节点,然后把相应部分切下来,想着能骗点分,没想到直接过了
点赞 回复 分享
发布于 2022-08-29 15:31 广东
确实选择题有点难,啥都有
点赞 回复 分享
发布于 2022-08-29 11:27 陕西
第一题的思路优先队列 我前几天刚看到 但是没用上😅牛啊
点赞 回复 分享
发布于 2022-08-29 08:39 陕西

相关推荐

首先讲三个故事,关于牛客的事件一:2024年,牛客上有一对高学历情侣,求职方向与我当时一致,都是嵌入式方向。他们恰好是我的朋友,专业能力和学历背景都很扎实,也因此拿到了不少优质offer。和很多求职者一样,他们把offer情况整理后发在平台上,本意是记录与交流,但很快引发了争议。有声音指责他们“集邮”“不释放名额”,认为这种展示本身就是一种炫耀。最终讨论失控,当事人删除内容,事件也很快被遗忘。事件二:小红书评论区,一条评价获得了不少共鸣:“感觉牛客就是当年那群做题区毕业了开始找工作还收不住那股味,颇有一种从年级第一掉到年纪第二后抱怨考不上大学的味道”,这条评论被水印里这个同学转发到牛客后,评论...
小型域名服务器:当看到别人比自己强的时候,即便这是对方应得的,很多人会也下意识的歪曲解构对方的意图,来消解自己在这本就不存在的比较中输掉的自信,从而平白制造出很多无谓的争论。比如你会在空余时间来写优质好文,而我回家只会暗区突围,那么我就可以作为键盘侠在这里评论你是不是XXXXXXXX。即便我自己都知道这是假的,但只要这没那么容易证伪,那么当你开始回应的时候,脏水就已经泼出去了,后面可能会有更多的人带着情绪来给我点赞,而毫不关注你写的文章内容本身是啥了。
SAGIMA牛马咖啡
点赞 评论 收藏
分享
评论
22
63
分享

创作者周榜

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