科大讯飞 8.29 AK

第一题
import java.util.Scanner;

public class Keda1 {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        String line = input.nextLine();
        String[] nums = line.split(",");
        int n = Integer.valueOf(nums[0]);
        int m = Integer.valueOf(nums[1]);
        int[][] pan = new int[n][m];
        for (int i = 0; i < n; i++) {
            String[] stmp = input.nextLine().split(" ");
            for (int j = 0; j < m; j++) {
                pan[i][j] = Integer.valueOf(stmp[j]);
            }
        }
        int[][] ans = pan;
        for (int i = 1; i < m; i++) {
            ans[0][i] = ans[0][i] + ans[0][i - 1];
        }
        for (int i = 1; i < n; i++) {
            ans[i][0] = ans[i][0] + ans[i - 1][0];
        }
        for (int i = 1; i < n; i++) {
            for (int j = 1; j < m; j++) {
                ans[i][j] = Math.max(ans[i - 1][j], ans[i][j - 1]) + ans[i][j];
            }
        }
        System.out.println(ans[n - 1][m - 1]);
    }
}

第二题
import java.util.Scanner;

public class Keda2 {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();
        int[] nums = new int[n];
        String s = input.next();
        String[] strings = s.split(",");
        for (int i = 0; i < n; i++) {
            nums[i] = Integer.valueOf(strings[i]);
        }
        sort(nums, n);
        StringBuilder ans = new StringBuilder();
        for (int i = 0; i < n; i++) {
            if (i == n - 1) {
                ans.append(nums[i] + "");
            } else {
                ans.append(nums[i] + ",");
            }
        }
        System.out.println(ans.toString());
    }

    private static void sort(int[] nums, int n) {
        for (int i = 0; i < n; i++) {
            int minNum = nums[i];
            int index = i;
            for (int j = i + 1; j < n; j++) {
                if (nums[j] < minNum) {
                    index = j;
                    minNum = nums[j];
                }
            }
            if (index != i) {
                int tmp = nums[i];
                nums[i] = nums[index];
                nums[index] = tmp;
            }
        }
    }
}

第三题
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class Keda3 {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        String line = input.nextLine();
        List<Character> res = new ArrayList<Character>();
        char[] chars = line.toCharArray();
        int n = chars.length;
        for (int i = 0; i < n; i++) {
            int j = i;
            boolean flag = true;
            while (j < n && chars[j] == '_') {
                j++;
                if (i != 0 && flag) {
                    res.add('_');
                    flag = false;
                }
            }
            if (j < n && chars[j] != '_') {
                res.add(chars[j]);
                i = j;
            }
        }
        int size = res.size();
        for (int i = size - 1; i >= 0; i--) {
            Character character = res.get(i);
            if (character != '_') {
                break;
            } else if (character == '_') {
                res.remove(i);
            }

        }
        StringBuilder ans = new StringBuilder();
        for (Character re : res) {
            ans.append(re);
        }
        System.out.println(ans.toString());
    }
}

第四题
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class Keda4 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        if (isZhiShu(n)) {
            System.out.println(n);
        }
        List<Integer> ans = new ArrayList<Integer>();
        zheng(n, ans, 2);
        int size = ans.size();
        StringBuilder stringBuilder = new StringBuilder();
        for (int i = 0; i < size; i++) {
            if (i == size - 1) {
                stringBuilder.append(ans.get(i));
            } else {
                stringBuilder.append(ans.get(i) + "*");
            }
        }
        System.out.println(stringBuilder.toString());
    }

    private static void zheng(int n, List<Integer> ans, int x) {
        if (isZhiShu(n)) {
            ans.add(n);
            return;
        }
        if (isZhiShu(x)) {
            if (n % x == 0) {
                ans.add(x);
                zheng(n / x, ans, x);
            } else {
                zheng(n, ans, x + 1);
            }
        } else {
            zheng(n, ans, x + 1);
        }
    }

    private static boolean isZhiShu(int n) {
        for (int i = 2; i <= Math.sqrt(n); i++) {
            if (n % i == 0) {
                return false;
            }
        }
        return true;
    }
}

#笔试题目##科大讯飞#
全部评论
第二题那个采样我看了半天没看懂,还以为第二个结果直接会转化成第三个结果,搞了半天原来是选择排序☹
点赞 回复 分享
发布于 2020-08-29 21:07

相关推荐

不愿透露姓名的神秘牛友
07-15 17:46
暑期就挂了,秋招还有机会吗
大聪明777:研发提前批,14号刚开的,官网上面的配图上有写。提前批没过的话,秋招还可以投,不过前面的笔试/面试记录会被保留,供秋招参考
26届校招投递进展
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-15 12:20
点赞 评论 收藏
分享
zYvv:双一流加大加粗再标红,然后广投。主要是获奖荣誉不够,建议开始不用追求大厂,去别的厂子刷下实习。
点赞 评论 收藏
分享
Twilight_m...:表格简历有点难绷。说说个人看法: 1.个人基本情况里好多无意义信息,什么婚姻状况、健康状况、兴趣爱好、户口所在地、身份证号码、邮政编码,不知道的以为你填什么申请表呢。 2.校内实践个人认为对找工作几乎没帮助,建议换成和测开有关的项目,实在没得写留着也行。 3.工作经历完全看不出来是干什么的,起码看着和计算机没啥关系,建议加强描述,写点你在工作期间的实际产出、解决了什么问题。 4.个人简述大而空,看着像AI生成,感觉问题最大。“Python,C,C++成为我打造高效稳定服务的得力工具”、“我渴望凭借自身技术知识与创新能力,推动人工智能技术的应用发展,助力社会实现智能化转型”有种小学作文的美感。而且你确定你个人简述里写的你都会嘛?你AI这块写的什么“深入研究”,发几篇顶会的硕博生都不一定敢这么写。而且你AI这块的能力和软测也完全无关啊。个人简述建议写你对哪些技术栈、哪些语言、哪些生产工具的掌握,写的有条理些,而且最好是和测开强相关的。
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

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