猿辅导9.12笔试第三题求解

第三题自己想的用例都通过了,死活是0,有没有大佬指导一下
public class three {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n=in.nextInt();
        String a=in.nextLine();
        for (int i = 0; i < n; i++) {
            sort(in.nextLine());
        }

    }

    public static void sort(String x){
        String[] s = x.split(" ");
        int a=0;
        int b=0;
        int c=0;
        int index=0;
        int num=Integer.valueOf(s[3]);
        if(s[0].length()+s[1].length()<s[2].length()) System.out.println(0);
        else if(s[0].charAt(0)!=s[2].charAt(0)&&s[1].charAt(0)!=s[2].charAt(0)){
            System.out.println(0);
        }else {
            while (index<num&&c<s[2].length()) {
                int l = sort(s[2], s[0], c, a);
                int r = sort(s[2], s[1], c, b);
                if(l==0&&r==0)break;
                if (l > r) {
                    c += l;
                    a += l;
                } else {
                    c += r;
                    b += r;
                }
                index++;
            }
            if(c==s[2].length()) System.out.println(1);
            else System.out.println(0);
        }
    }

    public static int sort(String x,String y,int x1,int y1){
        int index=0;
        while (y1<y.length()&&x1<x.length()&&y.charAt(y1)==x.charAt(x1)){
            y1++;
            x1++;
            index++;
        }
        return index;
    }
}



#笔试题目#
全部评论
同时出现a,比如ab,ac, 你会优先匹配第一个,这会产生一个问题,比如ac,你的代码就匹配错误。应该用回溯法来做
1 回复 分享
发布于 2020-09-12 23:18
用贪心会陷入局部最优而不是全局最优哦,试一试DP吧~
点赞 回复 分享
发布于 2020-09-12 22:14
有没有大神教下我第二题的输入怎么处理
点赞 回复 分享
发布于 2020-09-12 23:14
aaac aabb aaaabbac这种例子用贪心就会出问题
点赞 回复 分享
发布于 2020-09-13 01:36

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务