当前位置:首页 > 未命名 > 正文内容

交叉队列

淙嶙5年前 (2020-07-22)未命名995

描述


给出三个队列 s1,s2,s3 ,判断 s3 是否是由 s1 和 s2 交叉得来。
如:s1 为 aabcc , s2 为 dbbca。
当 s3 为 aadbbcbcac 时,返回 true(即将 s1 拆成三部分: aa,bc,c 分别插入 s2 对应位置)
否则返回 false。


输入


aabcc,dbbca,aadbbcbcac


输出


true


输入样例

aabcc,dbbca,aadbbcbcac
aabcc,dbbca,aadbbbaccc
a,b,ab
a,b,ba
a,b,ac
abc,bca,bcaabc
abc,bca,aabbcc

输出样例

true
false
true
true
false
true
false

private static String solution(String line) {
    // 在此处理单行数据
   String[] a = line.split(",");
String sub1=a[0];
String sub2=a[1];
String mainStr=a[2];
int result = analyzeString(mainStr,sub1,sub2);
if(result == 0){
return "true";
}
   return "false";
}
private static int analyzeString(String str,String subStr1,String subStr2){
if(str.length()==1 && (str.equals(subStr1) || str.equals(subStr2))){
return 0;
}
int remainLen = str.length();
if(subStr1.length() > 0){
String s = String.valueOf(subStr1.charAt(0));
if(str.startsWith(s)){
remainLen = Math.min(remainLen, analyzeString(str.substring(1),subStr1.substring(1),subStr2));
}
}
if(subStr2.length() > 0){
String s = String.valueOf(subStr2.charAt(0));
if(str.startsWith(s)){
remainLen = Math.min(remainLen, analyzeString(str.substring(1),subStr1,subStr2.substring(1)));
}
}
return remainLen;
}

相关文章

找出旋转有序数列的中间值

找出旋转有序数列的中间值

描述 给出一个有序数列随机旋转之后的数列,如原有序数列为:[0,1,2,4,5,6,7] ,旋转之后为[4,5,6,7,0,1,2]。假定数列中无重复元素,且数列长度为奇数。求出旋转数列的中间值...

Ubuntu安装docker

Ubuntu安装docker

1.查看ubuntu版本,官方指定的版本才能安装。https://docs.docker.com/install/linux/docker-ce/ubuntu/To install Docker CE...

在虚拟机里新安装Ubuntu无法全屏问题

在虚拟机里新安装Ubuntu无法全屏问题

除了本文外还有一种 完美解决Ubuntu16.04虚拟机窗口全屏问题,或者安装VMware Tools,单个人感觉还是简单就好,所以选择敲个命令完事。(转)在win7中用虚拟机安装了Ubuntu 16...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。