net.sf.rubycollect4j.iter.PermutationIterable Maven / Gradle / Ivy
/**
*
* @author Wei-Ming Wu
*
*
* Copyright 2013 Wei-Ming Wu
*
* 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 net.sf.rubycollect4j.iter;
import java.util.Iterator;
import java.util.List;
import net.sf.rubycollect4j.RubyArray;
/**
*
* {@link PermutationIterable} generates all permutations into a List with
* length n.
*
* @param
* the type of the elements
*/
public final class PermutationIterable implements Iterable> {
private final List extends E> list;
private final int n;
/**
* Creates a {@link PermutationIterable}.
*
* @param list
* a List
* @param n
* length of each permutation
* @throws NullPointerException
* if list is null
*/
public PermutationIterable(List extends E> list, int n) {
if (list == null)
throw new NullPointerException();
this.list = list;
this.n = n;
}
@Override
public Iterator> iterator() {
return new PermutationIterator(list, n);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder("[");
int index = 0;
for (RubyArray item : this) {
if (index == 0)
sb.append(item);
else
sb.append(", " + item);
index++;
}
sb.append("]");
return sb.toString();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy