去哪儿笔试0906(真难受)

三道算法

80   16.6    6

9.6去哪儿笔试(去哪儿笔试,难度适中(0906秋招笔试真题解析))

第一题

牛牛有一个由n个整数组成的数组[a1,a2,.,an],他想将这n个数打乱后依次拼接,使得拼接得到的字符串字典序是所有拼接字符串中最小的。直接输出这个打乱过后的数组。

输入描述

第一行输入一个整数n(1≤n≤10^5)代表数组中的元素数量。第二行输入n个整数a1,a2,...,an(0≤ai≤10^9)代表数组元素

输出描述

在第一行上输出n个整数,代表重新排列后的数组

示例1:

输入

32 1 -1

输出

-1 1 2

首先观察到一个性质:给定字符串a和b,如果a + b < b + a,那么在最终的数组中,a一定在b的前面(否则我们调换a和b的位置字典序一定会变得更小)。因此,我们根据a + b < b + a进行排序即可。

public static void main(String[] args) {
    Scanner in = new Scanner(System.in);
    int n = in.nextInt();
    in.nextLine();
    String[] ans=in.nextLine().split(" ");
    Arrays.sort(ans,(s1, s2)->(s1+s2).compareTo(s2+s1));
    for (String s:ans){
        System.out.printf("%s ",s);
    }
}

第二题

去哪儿会员体系分为大众、白银、黄金、铂金和钻石会员五个等级,等级由成长值决定,成长值越高,等级也就越高,也能够享受更多的会员权益。这天,牛牛发现可以通过完成每日任务的方式快速获得成长值提升等级!一共有n个任务,每天都会解锁一个新的任务,第i个任务达成后可以获得ai点成长值奖励。为了鼓励用户参与任务,在开始任务之前,还可以进入“挑战”模式,即预先设置自己能够坚持的天数x,在完成挑战后,可以得到前张奖励翻倍卡,你可以自由选择翻倍卡的使用顺序,使得每一天的成长值奖励翻倍,第i张翻倍卡可以将任务完成后的成长值奖励乘以bi倍,例如:第一天任务奖励1点成长值,第二天任务奖励2点成长值,奖励一张四倍翻倍卡和一张两倍翻倍卡,那么最少可以得到8点成长值,最多可以得到10点成长值。牛牛比较偷懒,他想要找到最少需要坚持的天数,使得自己能够获得至少m点成长值。

输入描述

第一行输入两个整数n和m(1≤n≤10^5;1≤m≤10^12)代表任务总数量和需要的成长值数量。第二行n个整数 a1,a2,..,an(0≤ai≤10^3)代表每一个任务奖励的成长值点 第三行n个整数b1,b2,..,bn(1≤bi≤10^3)代表按顺字摆放的翻倍卡的面值。

输出描述

在一行输出一个整数,代表最少坚持的天数;若永远无法达到目标,则直接输出-1

示例1:

输入:

5 20

1 2 3 4 5

4 2 3 5 10

输出:

3

容易观察到如果牛牛n天可以完成挑战,那么n+1天,n+2天....都可以完成挑战,因此我们二分天数,然后将前mid个任务根据成长值排序,将前mid个翻倍卡根据倍数进行排序,最后小的成长值乘小的翻倍卡即可。

public class Mian22 {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        String[] input = in.nextLine().split(" ");
        int n=Integer.parseInt(input[0]);
        long m=Integer.parseInt(input[1]);
        int[] res1=new int[n];
        String[] ans1=in.nextLine().split(" ");
        for (int i=0; i<n; i++) {
            res1[i]=Integer.parseInt(ans1[i]);
        }
        int[] res2=new int[n];
        String[] ans2=in.nextLine().split(" ");
        for (int i=0; i<n; i++) {
            res2[i]=Integer.parseInt(ans2[i]);
        }
        int l=0,r=n-1;
        while (l<=r){
            int mid=(r-l)/2+l;
            if(checkTrue(res1,res2,mid,m)){
                r=mid-1;
            }else {
                l=mid+1;
            }
        }
        System.out.println(l>=n?-1:(l+1));
    }
    public static boolean checkTrue(int[] res1,int[] res2,int mid,long m){
        int[] Ans1Copy= Arrays.copyOfRange(res1,0,mid+1);
        Arrays.sort(Ans1Copy);
        int[] Ans2Copy= Arrays.copyOfRange(res2,0,mid+1);
        Arrays.sort(Ans2Copy);
        long res=0l;
        for(int i=mid;i>=0;i--){
            res+=(long)Ans1Copy[i]*Ans2Copy[i];
            if(res>=m){
                return true;
            }

        }
        return false;
    }
}

第三题

如果一个字符串s可以由某个字符串t重复x(x>1)次得到,就称字符串s为一个真周期串。例如:s=01230123,t=0123,x=2。对于一个只包含数字0~9的字符串S,可以执行任意次(也可以不执行)操作,选择任意两个下标,交换两个下标的字符。更正式地说,选择i,j(i≠j)交换Si和Sj。如果字符串S经过操作后可以变成真周期串,那么称S为伪周期串。现在给定一个只包含数字0~9的字符串T,问:最多可以将字符串T划分成几个伪周期串?更正式地说,找出一个大小为k的伪周期串集合P,使得T=P1+P2+…+Pk输出最大的k。

输入描述

第一行输入一个整数n(1≤n≤2×10^3),表示字符串长度。第二行输入一个长度为n,且只包含数字字符的字符串T。

输出描述

在一行输入一个长度为n,且只包含数字字符的字符串T

示例:

输入:

801102222

输出

定义dp[i]为长度为i的前缀最多可以分为多少个,特别的,如果dp[i]为-1的话就代表这个前缀不可分。在过渡的时候,枚举以i为右端点的子字符串,判断子字符串是否是伪周期串并且前缀不能等于-1,然后更新答案。特别的,判断是否为伪周期串可以根据所有字符出现次数的最大公约数来判断,如果大于1,则是伪周期串。

package com.面试中的算法.去哪儿.去哪儿9_6秋招;

import java.util.Scanner;

/**
 * @author xing'chen
 * @version 1.0
 * @description: TODO
 * @date 2024/9/6 21:23
 */
public class Main33 {
    public static int gcd(int a, int b) {
        if (b == 0) return a;
        return gcd(b, a % b);
    }

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        String t = scanner.next();
        int[] dp = new int[n + 1];
        dp[0] = 0;

        for (int i = 1; i <= n; i++) {
            int[] cnt = new int[10];
            for (int len = 1; len <= i; len++) {
                int id = t.charAt(i - len) - '0';
                cnt[id]++;
                int g = 0;
                for (int j = 0; j < 10; j++) {
                    g = gcd(g, cnt[j]);
                }
                if (g > 1 && dp[i - len] != -1) {
                    dp[i] =Math.max(dp[i], 1 + dp[i - len]);
                }
            }
        }

        System.out.println(dp[n]);
    }
}

麻了能不能给个面试我以后只在去哪儿订酒店

#去哪儿求职进展汇总##秋招##投票##去哪儿旅行秋招#
秋招笔面记录 文章被收录于专栏

秋招中的笔试以及面记录

全部评论
1 1 0.2希望进面
1 回复 分享
发布于 2024-09-07 09:21 北京
打个广告 没投度小满的 投我的内推啊
1 回复 分享
发布于 2024-09-08 11:51 北京
90 36.6 0
点赞 回复 分享
发布于 2024-09-06 23:30 上海
第一道mysql不会,其余两道很简单呀
点赞 回复 分享
发布于 2024-09-06 23:33 广东
笔试不是很重要 看学历
点赞 回复 分享
发布于 2024-09-06 23:57 北京
100 50 10
点赞 回复 分享
发布于 2024-09-07 00:21 重庆
100 100 36 话说去哪儿hc多吗
点赞 回复 分享
发布于 2024-09-07 01:02 山东
1,0.2,0.2。做的我崩溃
点赞 回复 分享
发布于 2024-09-07 10:58 湖南
昨天真红了 20 36.6 20🐔了
点赞 回复 分享
发布于 2024-09-07 14:55 河南
1 1,0.133。最后一题只需要字符串长度除以6,就能骗0.133
点赞 回复 分享
发布于 2024-09-07 22:16 四川
100 100 40
点赞 回复 分享
发布于 2024-09-08 14:24 广东
测开1 0.9 0.45
点赞 回复 分享
发布于 2024-09-08 16:24 江西
100,100,40,最后一题一开始用回溯,一直找不到错误的点,最后剩点时间找到错误示例来不及了
点赞 回复 分享
发布于 2024-09-08 20:07 江苏
a+b <b+a这个性质是怎么观察到的
点赞 回复 分享
发布于 2024-09-09 17:37 海南
9.6这批有面试通知了吗?
点赞 回复 分享
发布于 2024-09-11 16:30 湖南

相关推荐

正在干活结果人事过来找我,说我被裁了,还说要裁一半,一些没转正的先踢出去…&nbsp;真是牛逼现在的公司,怪不得越做越小。上个月初提交的转正申请,我老大也同意了,我真以为我转正了,结果人事跟我说我老大不知道这些,好吧那你们瞒着呗真是逆天…&nbsp;又要开始找工作了,现在工作哪里这么好找,还有这么多公司喜欢这种操作,坑我们应届生真服了👿
CoderEcho:看你的主页,你好像是有点内向,不怎么说话?我之前实习也是这样的,hr和主管也是用我太内向导致的主管看不到头,工作习惯不好,不适合他们这样的原因把我实习劝退,但是公司肯定有公司的问题,因为去年没一个实习转正的,连社招生都劝退。倒也不是替公司说话,只是一些建议,公司内部裁员肯定是公司的问题,只是积极主动(或者领导眼中积极主动)的人未来一定会有更多机会,刚被劝退的时候基本上秋招已经结束,但是1月份的时候还是上岸啦,并且面试时我说出了我对积极主动的理解也是加分的一点。祝你继续加油往前走,大厂经历+985学历,结果一定不会差的啦
点赞 评论 收藏
分享
评论
6
24
分享

创作者周榜

更多
牛客网
牛客企业服务