Skip to content

Latest commit

 

History

History
56 lines (32 loc) · 5.65 KB

README.md

File metadata and controls

56 lines (32 loc) · 5.65 KB

Princeton-Algorithm

Cousera online course, Introduction to Algorithms (part1) and Introduction to Algorithms (part2), created by Princeton University, taught by: Kevin Wayne, Senior Lecturer and Robert Sedgewick, Professor.

The course feathers in its autograder, whose Assessment Details section is subdivided into Compilation, API, SpotBugs, PMD, Checkstyle, Correctness, Memory, and Timing.

This repository contains my assignments source code.

Assignments Specifications and Tips

The Backwash Problem: Backwash is a like a false positive for isFull method and arises after a system percolates. Here a site is not connected to top, but isFull method returns true because its connected to any site bottom site and bottom in turn is connected to top via (using virtual bottom) some other path. Fact is water flows down only from top to bottom, but here a short circuit of connectivity happens.

It comes as a result of using both virtual top and virtual bottom. Another way is to use 2 copies of UF data structure to keep calculations separate.

More advanced way will be to maintain additional state with each site (using single UF) on whether its connected to bottom. This is quite tricky to figure out.

Randomized Queues: I tried first using a linked list because I thought the access time will be faster than the array approach but the problem was the memory usage and the running time; I switch to the array implementation and my biggest concern here was "how I order the array after remove a random element from it to avoid having null elements in between? and how I do it fast?", well the answer it's pretty simple, because the order doesn't matter, there's no need to order the array but to swap the random selected element with the latest element in the array, then just return that latest element and mark it null; About the iterator, as Tomasz Pankowski said, the important part is the "amortized time", the assignment give us a little hint : "you may (and will need to) use a linear amount of extra memory per iterator."

Points: Use Double.POSITIVE_INFINITY & Double.NEGATIVE_INFINITY to describe $+\infty$ & $-\infty$

FastCollinearPoints: How to avoid duplicating segment? One simple way is to order the Points array and check the order of adjacent points to ensure we find collinear points in order: consider we go through the ordered coloned Points array ${p_n}$, since the iterator variant $p$ is ordered by the comparator of Points, it will cause a negative comparison result if we find the collinear points $p_i$ of $p_j$ where $ i<j (p_i<p_j)$ .

Twin: By the parity of inversed pairs (e.g if the tiles are arranged like this:

1 2 3
4 5 8
6 7 0

then we have the inversed pairs $(8,6)$, $(8,7)$. If the number of inversed pairs is even, then we the puzzle is solvable, vice versa. This can be easily proved if you know permutation group), we know that the twin board has the opposite parity of inversed pairs. Thus, one of them must be solvable. Since we are not supposed to write functions to calculate the inversed pairs of the initial board, we just try to find the solution of both the origin one and the twin one and finally we just need to check from which one we get the solution.

Time Performance: I had stuck in the time performance for a while until I find that I put the mahattan algorithm the manhattan function and the Solver.java just get through it every time it has to compare. The solution to this is that to calcute the manhattan distance in the Board Builder and put it into a variant in class Board and SearchNode.

Three seems to be some bugs in the autotest... especially when using range() and nearest(). The points supposed to be counted are sometimes get expelled...

Note that the class DepthFirstDirectedGraph in the algs4.jar does not have a distTo() function while BreathFirstDirectedGraph does. Remember to use classes DirectedCycle to check if graph has cycles or Topological to check DAG.

This is a simplifies algorithm of "smart" graph resizing without any machine learning! Fabulous!

Remember to check that client can mutate the Picture object that is passed to the constructor and that is returned by picture(), this may lead to 99/100.

A little bit imagination of matrice transpose may simplify codes a lot when it comes to converting horizontal to vertical.

The use of mincut: no full forward means $s$ to games edges with nonzero residual capacity. If we traverse further from games vertices to team vertices, the edges have positive infinite capacity, so the teams which non zero remaining games have a non empty backward capacity, so they are also included in the mincut. The last layer $t$, has all its capacity filled so it has a empty capacity in backward direction, and has no forward edges.