科大讯飞笔试 AK

第一题:倒序输出即可

public class App {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        for (int i = n; i >= 1; i--)
            System.out.print(i+" ");
    }
}

第二题:一次遍历:

public class App {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt(), k = sc.nextInt();
        String s = sc.next();
        if (s.length() == 1) {
            System.out.println(k);
            return;
        }
        int i = 1;
        for (i = 1; i < s.length(); i++) {
            int diff = s.charAt(i) - s.charAt(i - 1);
            k -= diff;
            if (k < 0)
                break;
        }
        System.out.println(i == s.length() ? k : -1);
    }
}

第三题:记录重复长度


public class App {

    public static void main(String[] args) throws Exception {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] arr1 = new int[n], arr2 = new int[n];
        Map<Integer, Integer> map = new HashMap<>();
        for (int i = 0; i < n; i++)
            arr1[i] = sc.nextInt();
        for (int i = 0; i < n; i++) {
            arr2[i] = sc.nextInt();
            map.put(arr2[i], i);
        }
        long sum = (long) n * (n + 1);
        int cnt = 1;
        for (int i = 0; i < arr1.length; i++) {
            int idx = map.get(arr1[i]);
            if (idx < n - 1 && i < n - 1 && arr2[idx + 1] == arr1[i + 1]) {
                cnt++;
            } else {
                sum -= (long) (cnt + 1) * cnt / 2;
                cnt = 1;
            }
        }
        System.out.println(sum);
    }
}

#科大讯飞信息集散地##科大讯飞求职进展汇总#
全部评论
我擦第一题原来就这暴力只能过60,原来倒序就是答案
2 回复 分享
发布于 2023-08-13 16:10 北京
佬,可以请问一下第三题最后那个循环的思路吗?谢谢佬
点赞 回复 分享
发布于 2023-08-13 16:07 河南
牛逼
点赞 回复 分享
发布于 2023-08-13 16:11 浙江
第三题一模一样为啥只有20%
点赞 回复 分享
发布于 2023-08-13 16:17 湖北
题目有说数组1和数组2的值都一样吗?只是排序不一样?
点赞 回复 分享
发布于 2023-08-13 16:18 上海
真难受
点赞 回复 分享
发布于 2023-08-13 16:27 甘肃
wc,第三题原来如此
点赞 回复 分享
发布于 2023-08-13 16:33 江苏
我真蠢啊,忘记强转成longlong了
点赞 回复 分享
发布于 2023-08-13 16:38 上海
第三题为什么sum一开始是n*(n+1)不是n*(n+1)/2呢?
点赞 回复 分享
发布于 2023-08-14 09:25 重庆
第一题为什么加个空格就不超时了啊, 我直接用stringbuilder做的
点赞 回复 分享
发布于 2023-08-14 15:18 四川
佬,题目有吗
点赞 回复 分享
发布于 2023-08-25 09:59 江苏

相关推荐

工作30年还房贷:比赛加学历就已经够了。你要挑点毛病的话,项目写的不行,没有突出深度,你可能做了很多深度工作,但给别人的感觉都是做的很简单的工作。
点赞 评论 收藏
分享
评论
5
14
分享
牛客网
牛客企业服务