给定一个字符串source和一个目标字符串target,在字符串source中找到包括所有目标字符串字母的子串。
注意事项
如果在source中没有这样的子串,返回"",如果有多个这样的子串,返回起始位置最小的子串。
说明在答案的子串中的字母在目标字符串中是否需要具有相同的顺序?
——不需要。
给出source = "ADOBECODEBANC",target = "ABC" 满足要求的解 "BANC"
public class Solution {
/**
* @param source: A string
* @param target: A string
* @return: A string denote the minimum window
* Return "" if there is no such a string
*/
public String minWindow(String source, String target) {
// write your code
if(source.length()<target.length()){
return "";
}
for(int i=target.length();i<=source.length();i++){
for(int j=0;j+i<=source.length();j++){
String s=source.substring(j, j+i);
StringBuffer sb=new StringBuffer(s);
int count=0;
for(int k=0;k<target.length();k++){
if(sb.indexOf(target.charAt(k)+"")!=-1){
sb.deleteCharAt(sb.indexOf(target.charAt(k)+""));
count++;
}else{
break;
}
}
if(count==target.length()){
return s;
}
}
}
return "";
}
}