2010-10-24 145 views
0

我正在尝试做一个方法来帮助我拼写世界的权利。 addChar已根据输入"famili"返回其工作,我希望结果数组包含单词"familiy"。现在该方法从字符串中删除一个字符并将其替换为alpha[]中的当前字符,有人请给我一些帮助,以使此方法在两个字符之间添加来自alpha[]的字符,并且不删除一个字符以获取空间。在字符串中添加字符一个地方

class Main { 
     char [] alpha = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 
         'l', 'm','n', 'o', 'p', 'q', 'r', 's', 't', 'y', 'z'}; 
     public static void main(String [] args) { 

      Main m = new Main(); 
      String [] result = m.addChar("famil"); 
     } 

     public String[] addChar(String word) { 

      String [] words = new String[word.length() * alpha.length]; 
      int k = 0; 

      for(int i = 0; i < alpha.length; i++) { 
       for(int j = 0; j < word.length(); j++) { 
        StringBuffer buf = new StringBuffer(word); 
        buf.setCharAt(j, alpha[i]); 
        words[k++] = buf.toString(); 
       } 
      } 
      return words; 
     } 
} 

回答

1

我可能会解决这个问题是这样的。

for (int i = 0; i < alpha.length; i++) 
    for (int j = 0; j < word.length(); j++) 
     words[k++] = word.substring(0, j) + alpha[i] + word.substring(j); 
相关问题