A collection of data structures and algorithms for programming contests written in Java. It is not organised as a library, but rather like a loose collection of helper methods/class that can be copy-pasted into a Java class to be submitted to an online judge.
To be completed
Variant of the Arne Andersson tree, where an additional integer is stored in each node, in order to be able to perform order-statistic queries. An integer may be inserted multiple times, which increases the occurrence counter in the node.
Operation | Complexity | Description |
---|---|---|
aaContains |
O(log(n)) |
Checks whether the given integer exists in the tree |
aaDelete |
O(log(n)) |
Deletes the given integer from the tree |
aaDifference |
O(m+n) |
Calculates the (multi)set difference between two AA trees (recursive implementation !) |
aaInorder |
O(n) |
Performs a Morris inorder tree traversal |
aaInsert |
O(log(n)) |
Inserts an integer into the tree |
aaIntersection |
O(m+n) |
Calculates the (multi)set intersection between two AA trees (recursive implementation !) |
aaOccurrence |
O(log(n)) |
Returns the occurrence count of the integer passed as parameter |
aaPostorder |
O(n) |
Performs a Morris postorder tree traversal |
aaPreorder |
O(n) |
Performs a Morris preorder tree traversal |
aaRank |
O(log(n)) |
Calculates the rank of the integer, wrt to the values stored in the tree |
aaSelect |
O(log(n)) |
Returns the node with the given rank |
aaUnion |
O(m+n) |
Calculates the (multi)set union between two AA trees (recursive implementation !) |
Tree internals: each node stores a tuple (AANodeInt[] children, int level, int nNodes, int occurrence, int size, int value)
. Of those fields, only children
, level
and value
are strictly necessary for an AATree. The other ones are used as bookkeeping values for order-statistics / tree traversal operations. While the the tree may store up to INTEGER.MAX_VALUE elements, you might want to use a B-Tree well before reaching this limit.
The IO class defines three helper streams that can be statically imported.
FastPrintWriter
is a BufferedOutputStream
that has been decorated with a PrintWriter
. It provides the following overloaded print
and println
methods (a boolean argument for newlines may be provided where applicable):
Type | Remarks |
---|---|
print(int) |
|
print(long) |
|
print(double) |
|
print(T) |
Calls the toString method defined on T |
println() |
Prints an empty line |
println(int) |
|
println(long) |
|
println(double) |
|
println(T) |
Calls the toString method defined on T |
println(int[]) |
|
println(long[]) |
|
println(double[]) |
|
println(T[]) |
Calls the toString method defined on T |
println(Collection<T>) |
|
println(Map<T, U>) |
key1 -> value1, ... , keyN -> valueN |
println(int[][]) |
Prints the 2D-array contents in row-major order |
println(long[][]) |
Prints the 2D-array contents in row-major order |
println(double[][]) |
Prints the 2D-array contents in row-major order |
println(T[][]) |
Prints the 2D-array contents in row-major order. Calls the toString method defined on T |
Type | Remarks |
---|---|
int nextInt() |
Reads the next int from System.in |
int[] nextInts(int n) |
Reads the n next int s from System.in |
int[] nextInts(int n, boolean oneBased) |
Fills in the array starting from index 1 if oneBased is true |
int[] nextInts(int n, int iMin) |
Fills in the returned array between iMin and iMin+n |
long nextLong() |
|
long[] nextLongs(int n) |
|
long[] nextLongs(int n, boolean oneBased) |
|
long[] nextLongs(int n, int iMin) |
|
double nextDouble() |
|
double[] nextDoubles(int n) |
|
double[] nextDoubles(int n, boolean oneBased) |
|
double[] nextDoubles(int n, int iMin) |
This scanner defines methods that are similar to the ones from FastScanner
. However, instead of reading from the System.in stream, random numbers are returned. This may be useful for stress-testing a solution.
checksub [folder] [classname] [firsttestcase] [lasttestcase]
: compiles and runs the class against the given testcases (the file extension for testcase input files must be.in
, and.out
for sample output files).maketests [folder] [classname] [firsttestcase] [lasttestcase]
: creates an empty .java file, along with empty testcase input / output files.
- Add debug methods to IO Helpers
- Additional computational geometry algorithms
- Graph algorithms
- Binomial heaps
- Segment trees
- Network flows
- Splay trees
- Suffix trees / arrays
- Fast Fourier Transform
- Follow me on [][https://github.com/jean-andre-gauthier]
- Follow me on [][https://twitter.com/jandre_gauthier]