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那样一个接一个的话,它就不起作用了。在您最初的测试用例中没有看到这一点。这是一种效率极低的方法,但是您可以生成所有要匹配的单词排列,然后让一个嵌套循环遍历它们并检查每个单词是否包含。