/******************************************************************************
* Copyright (C) 2014 Yevgeny Krasik *
* *
* Licensed under the Apache License, Version 2.0 (the "License"); *
* you may not use this file except in compliance with the License. *
* You may obtain a copy of the License at *
* *
* http://www.apache.org/licenses/LICENSE-2.0 *
* *
* Unless required by applicable law or agreed to in writing, software *
* distributed under the License is distributed on an "AS IS" BASIS, *
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
* See the License for the specific language governing permissions and *
* limitations under the License. *
******************************************************************************/
package com.github.ykrasik.jaci.util.trie;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
* @author Yevgeny Krasik
*/
public class StringGenerator {
private static final char DEFAULT_START_CHAR = 'a';
private final char startChar;
private final int numChars;
public StringGenerator(int numChars) {
this(DEFAULT_START_CHAR, numChars);
}
public StringGenerator(char startChar, int numChars) {
this.startChar = startChar;
this.numChars = numChars;
}
public List<String> generateAllFixedLengthStringPermutations(int length) {
if (length == 0) {
return Collections.singletonList("");
}
final List<String> permutations = generateAllFixedLengthStringPermutations(length - 1);
final List<String> strings = new ArrayList<>(permutations.size() * numChars);
for (int i = 0; i < numChars; i++) {
final char c = charPlus(startChar, i);
for (String permutation : permutations) {
strings.add(c + permutation);
}
}
return strings;
}
private char charPlus(char c, int i) {
return (char) (c + i);
}
}