Java从单词中删除部分
你好,我不能做这项工作,我被赋予了一个主词后,再加上另一个子词,如果这个词是包含在主词的部分应删除Java从单词中删除部分,java,Java,你好,我不能做这项工作,我被赋予了一个主词后,再加上另一个子词,如果这个词是包含在主词的部分应删除 //Example //fmrog (in.nextLine)(main word) //4 (in.nextInt)(the amount of sub words) //roc(in.nextLine)(not contained) //gor(in.nextLine)(not contained) //rog(in.nextLine)(contained) //ogr(in.nextLin
//Example
//fmrog (in.nextLine)(main word)
//4 (in.nextInt)(the amount of sub words)
//roc(in.nextLine)(not contained)
//gor(in.nextLine)(not contained)
//rog(in.nextLine)(contained)
//ogr(in.nextLine)(not contained)
//result:fm
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
StringBuilder mainWord = new StringBuilder(in.nextLine);
int n = in.nextInt();
StringBuilder MainWord2 = new StringBuilder(mainWord);
in.nextLine();
for (int i = 0; i < n; i++) {
String subWord = in.nextLine();
int chars = subWord.length();
if (chars> mainWord.length()){
continue;
}
for (int j = 0; j < subWord.length(); j++) {
int r = 0;
for (int k = 0; k < mainWord.length(); k++) {
r++;
if (k > MainWord2.length() - 1) {
break;
}
if (MainWord2.charAt(k) == subWord.charAt(j)) {
break;
}
}
if (r <= MainWord2.length() && MainWord2.charAt(r-1) == subWord.charAt(j)) {
MainWord2.deleteCharAt(r - 1);
if (j >= subWord.length() -1 ) {
mainWord = MainWord2;
break;
}
}
if (r > MainWord2.length()) {
MainWord2 = mainWord;
break;
}
}
}
System.out.println(mainWord);
}
}
老实说,我很沮丧,也许有更简单的方法来解决这个问题。最主要的是,当我写一个例子,比如:super 2 pe surr,在surr的末尾,当我删除其中一个的chatAt时,两个stringbuilder开始作为一个,另一个也发生了变化,无需如此复杂
String input = // complete user input
String[] words = String.split(input);
String mainWord = words[0];
int numWords = Integer.parseInt(words[1]); // this variable isn't needed
for(int i = 2; i < words.length; i++) {
if (mainWord contains words[i]) {
mainWord = mainWord.replace(words[i], ""); // remove subword from mainword
}
}
最后,mainWord将是原始的mainWord,没有任何后来输入的子词
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
in.nextLine();
String[] words = new String[n];
for (int i = 0; i <n ; i++) {
words[i] = in.nextLine();
}
String mainWord = words[0];
for (int i = 1; i <words.length ; i++) {
if (mainWord.contains(words[i])){
mainWord = mainWord.replace(words[i], "");
}
}
System.out.println(mainWord);
}
}
这里的问题是,如果字母不是一个挨着另一个,它不会删除子单词。嘿,我是这样做的,但如果字母不是一个挨着另一个,它就不起作用,就像我可以拥有ose一样。嘿,我是这样做的,但是如果字母不是像house i can ose那样一个接一个的话,它就不起作用了。在您最初的测试用例中没有看到这一点。这是一种效率极低的方法,但是您可以生成所有要匹配的单词排列,然后让一个嵌套循环遍历它们并检查每个单词是否包含。