1

如果我有一个字符串,说“ABCDE”,那么获得两者组合的最佳方法是什么?是否有用于此类任务的 API?

IE

  1. “AB”
  2. “交流”
  3. “广告”
  4. “AE”
  5. “公元前”
  6. “BD”
  7. “是”
  8. “光盘”
  9. “行政长官”
  10. “德”
4

3 回答 3

1

没有 API。最好的阅读来源是 Knuth “The Art of Computer Programming Vol 1”或类似的内容:

http://webhome.csc.uvic.ca/~haron/CoolCocoon.pdf

于 2012-04-18T13:13:39.567 回答
1
private static List<String> getCombinations(String input) {
    ArrayList<String> result = new ArrayList<String>();
    int len = input == null ? 0 : input.length();
    for (int i = 0; i < len - 1; i++) {
        for (int j = i + 1; j < len; j++) {
            String combination = String.valueOf(input.charAt(i))
                    + input.charAt(j);
            System.out.println("adding: " + combination);
            result.add(combination);
        }
    }
    return result;
}

getCombinations("ABCDE");

adding: AB
adding: AC
adding: AD
adding: AE
adding: BC
adding: BD
adding: BE
adding: CD
adding: CE
adding: DE
于 2012-04-18T13:27:48.237 回答
0

i+1伪代码:

    String alphabet = "ABCDE";
    for( int i = 0; i < alphabet.getLength(); i++){
     for( int j = alphabet.getLength(); j > i; j--){
       System.out.println( alphabet.substring(i, i+1) + alphabet.substring(j, j+1) );
     }
    }

如果您需要更多组合,例如:BA CA 等等,因为只有 2 个字母,您可以切换它们的位置并将此过程的结果附加到生成的对中。如果您需要三个等的组合,请查看置换算法。

于 2012-04-18T13:25:23.073 回答