diff --git a/src/aud/exam/prep/SequenceProcessor.java b/src/aud/exam/prep/SequenceProcessor.java index f73372a..f2d2636 100644 --- a/src/aud/exam/prep/SequenceProcessor.java +++ b/src/aud/exam/prep/SequenceProcessor.java @@ -2,6 +2,14 @@ package aud.exam.prep; import java.util.Comparator; +/** + * Instances of this interface can work with any "valid" sequences of type S. + * For what is valid, see {@link #check(S)}. + * This is a literal translation of the "inspiration sheet" into java. + * + * @param Type of elements stored in S + * @param Type of the sequence + */ public interface SequenceProcessor { boolean find(S s, T t); @@ -26,8 +34,6 @@ public interface SequenceProcessor { T secondMax(S s, Comparator cmp); - boolean check(S s); - boolean isItemWiseLessOrEqual(S a, S b, Comparator cmp); boolean isItemWiseLess(S a, S b, Comparator cmp); @@ -62,7 +68,32 @@ public interface SequenceProcessor { Pair divideByPivot(S s, T pivot, Comparator cmp); + /** + * Check whether ot not the given sequence is "valid" according to + * what is considered valid depends on the specific data structure. + * This is also used by the tests. + * + * @param s A sequence + * @return true iff the given sequence is valid + */ + boolean check(S s); + + /** + * Create a sequence from an {@link Iterable}. + * This is required by the tests. + * + * @param iterable An {@link Iterable} + * @return A sequence with the elements of the given iterable + */ S create(Iterable iterable); + /** + * Return an {@link Iterable}, or a lambda returning {@link java.util.Iterator}, + * over the elements of the sequence s. + * This is required by the tests. + * + * @param s A sequence + * @return An {@link Iterable} over s + */ Iterable iterate(S s); }