小红书9.4后端AK代码

最近难得的一次AK,记录一下。
1、镜像复制
问题描述:给定n,m,k(n>=1,m>=1,k<=1e18)
根据n得到[1, 2, 3, …, n],进行m次镜像复制
每次镜像复制,例如:[1, 2, 3]->[1,2,3,3,2,1]
求m次镜像复制后第k个数
解题思路:找规律,最少镜像复制一次,从第2次开始,数组每2n个元素一次循环,即[1, 2, 3, 3, 2, 1][1, 2, 3, 3, 2, 1]。
代码
public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int m = sc.nextInt();
        long k = sc.nextLong();
        int[] arr = new int[2 * n];
        for(int i = 0; i < n; i++) {
            arr[i] = sc.nextInt();
            arr[2 * n - i - 1] = arr[i];
        }
        System.out.println(arr[(int)((k - 1) % (2 * n))]);
    }
}
2、n个数,乘积为7
问题描述:给定n个数,每个数每次操作可以+1,或-1。求最少的操作次数使得这n个数乘积为7.
解题思路:7是质数,所以最终数组会出现一个7或-7,其他均为1或-1.
首先可以把问题划分为两个问题:
1、记录每个数,正数转化为1,负数转化为-1,所需要操作数,累加的a。
2、记录每个数,正数转化为7,负数转化为-7,比1或-1少的次数,取最大值b。
3、结果=a-b。
4、特殊情况考虑,数组存在0,则不考虑负数个数的奇偶性(0变为-1和1次数相同)。
5、数组不存在0,负数为偶数也不考虑,负数为正数需要将其中一个从-1变为1,即多进行2次操作,结果为res+2.
代码
public class Main {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] arr = new int[n];

        int under = 0;
        int zero = 0;
        for(int i = 0; i < n; i++) {
            arr[i] = sc.nextInt();
            if(arr[i] < 0) {
                under++;
            }else if(arr[i] == 0){
                zero++;
            }
        }

        long res = 0;
        int[] nums = new int[n];
        int minV = Integer.MAX_VALUE;
        for(int i = 0; i < n; i++) {
            nums[i] = Math.min(Math.abs(arr[i] - 1), Math.abs(arr[i] + 1));
            int temp = Math.min(Math.abs(arr[i] - 7), Math.abs(arr[i] + 7));
            minV = Math.min(minV, temp - nums[i]);
        }
        for(int i = 0; i < n; i++) {
            res += nums[i];
        }
        res += minV;
        if(zero == 0 && under % 2 == 1) {
            System.out.println(res + 2);
        }else {
            System.out.println(res);
        }
    }
}
3、旅游,一个国家由1,2,…,n这些城市,从1出发,目的地为n。边的长度为1,花费为cost。现有一张特权卡M,花费小于M的边可以通过。求深度不超过k的情况下,M的最小值。
解题思路:深度优先搜索,城市数据量很大,使用邻接表存储。
class Node {
    int id;
    Map<Integer, Integer> next;
    public Node(int id) {
        this.id = id;
        next = new HashMap<>();
    }
}

public class Main {

    private static Map<Integer, Node> nodes;
    private static int k;
    private static int n;
    private static int minVal = Integer.MAX_VALUE;
    private static Set<Integer> visited = new HashSet<>();

    public static void dfs(Node loc, int maxCost, int depth) {
        if(depth > k) {
            return ;
        }
        if(loc.id == n) {
            minVal = Math.min(minVal, maxCost);
        }
        for(Map.Entry<Integer, Integer> entry: loc.next.entrySet()) {
            int key = entry.getKey();
            int value = entry.getValue();
            if(!visited.contains(key)) {
                visited.add(key);
                dfs(nodes.get(key), Math.max(maxCost, value), depth + 1);
                visited.remove(key);
            }
        }
    }

    public static void main(String[] args) {
        nodes = new HashMap<>();
        Scanner sc = new Scanner(System.in);
        n = sc.nextInt();
        int m = sc.nextInt();
        k = sc.nextInt();
        int[][] edges = new int[m][3];
        for(int i = 0; i < 3; i++) {
            for(int j = 0; j < m; j++) {
                edges[j][i] = sc.nextInt();
            }
        }

        for(int i = 1; i <= n; i++) {
            nodes.put(i, new Node(i));
        }
        for(int i = 0; i < m; i++) {
            int u = edges[i][0];
            int v = edges[i][1];
            int w = edges[i][2];
            nodes.get(u).next.put(v, w);
            nodes.get(v).next.put(u, w);
        }
        if(n == 1) {
            System.out.println(0);
        }else {
            dfs(nodes.get(1), Integer.MIN_VALUE, 0);
            System.out.println(minVal);
        }
    }
}



#笔试##小红书##2023秋招##23届秋招笔面经#
全部评论
大佬第二题ac了嘛?我和你思路一样但是只过了55
2 回复 分享
发布于 2022-09-04 18:19 浙江
同ak,楼主思路很清晰😝
点赞 回复 分享
发布于 2022-09-04 18:20 天津
我c++最后一题用dfs卡在82
点赞 回复 分享
发布于 2022-09-04 18:56 浙江
hi~同学,秋招遇“寒气”,牛客送温暖啦!23届秋招笔面经有奖征集中,参与就得牛客会员7天免费体验,最高赢300元京东卡!戳我去看>>>https://www.nowcoder.com/link/zhengjipinglun
点赞 回复 分享
发布于 2022-09-05 11:07 北京
第一题,应该不用创建2n个数组吧,不复制m=0呢,或n很大耗资源。 您看看这个行不行:
点赞 回复 分享
发布于 2022-09-06 00:00 江西
最近难得的一次记录一下
点赞 回复 分享
发布于 2022-10-22 17:09 河南

相关推荐

2024-12-31 11:16
已编辑
北京邮电大学 Java
KalznAsawind:标准的八股问烂简历,面试官碰到这种简历一般都会开始轰炸八股了。其实我一直觉得项目、实习的作用是将面试官困在你的语境中,在你的语境中跟他解释项目背景和细节,跟他battle,减少他轰炸你八股的时间,这样压力会小很多。但是你的项目是一眼无落地、无背景的包装项目,所以对方也不会去在意你的项目背景,只会针对你的项目涉及的技术栈开始轰炸八股,会增大你的压力,而你面试过不过全看你八股背的熟不熟。
点赞 评论 收藏
分享
2024-12-27 23:45
已编辑
三江学院 Java
程序员牛肉:死局。学历+无实习+项目比较简单一点。基本就代表失业了。 尤其是项目,功能点实在是太假了。而且提问点也很少。第一个项目中的使用jwt和threadlocal也可以作为亮点写出来嘛?第二个项目中的“后端使用restful风格”,“前端采用vue.JS”,“使用redis”也可以作为亮点嘛? 项目实在是太简单了,基本就是1+1=2的水平。而你目标投递的肯定也是小厂,可小厂哪里有什么培养制度,由于成本的问题,人家更希望你来能直接干活,所以你投小厂也很难投。基本就是死局,也不一定非要走后端这条路。可以再学一学后端之后走测试或者前端。 除此之外,不要相信任何付费改简历的。你这份简历没有改的必要了,先沉淀沉淀
点赞 评论 收藏
分享
评论
10
38
分享

创作者周榜

更多
牛客网
牛客企业服务