当前位置: 首页 > 面试经验 >

小红书9.4后端AK代码

优质
小牛编辑
155浏览
2023-03-28

小红书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届秋招笔面经#
 类似资料: