Posts

Showing posts with the label data structures

The WeakReference class, monitoring memory leak and garbage collection in a Java application

Image
 Below is a Stack implementation that uses an internal resizeable array structure.  public class MyStack< T > implements Stack< T > { private static final int CAPACITY = 100 ; private Object[] array ; private int pos = 0 ; public MyStack () { this . array = new Object[ CAPACITY ] ; } @Override public void push ( T item) { if ( pos >= array . length / 2 ) { Object[] newArray = new Object[ pos * 2 ] ; System. arraycopy ( array , 0 , newArray , 0 , array . length ) ; array = newArray ; } array [ pos ++] = item ; } @Override public T pop () { if (isEmpty()) { throw new RuntimeException( "empty stack" ) ; } @SuppressWarnings ( "unchecked" ) T item = ( T ) array [ pos - 1 ] ; pos -= 1 ; return item ; } @Override @SuppressWarnings ( "unchecked" ) public T peek...

Dynamic Connectivity Problem and the Union-Find Algorithm

Lets say we need to connect some objects and query if some objects are connected or not. Below is an example test: @Test     public void testConnectivity() {         MyConnectionDb connectDb = new MyConnectionDb();         connectDb.connect(4, 3);         connectDb.connect(3, 8);         connectDb.connect(6, 5);         connectDb.connect(9, 4);         connectDb.connect(2, 1);         assertTrue(connectDb.isConnected(8, 9));         assertFalse(connectDb.isConnected(5, 4));         connectDb.connect(5, 0);         connectDb.connect(7, 2);         connectDb.connect(6, 1);         connectDb.connect(7, 3);         assertTrue(connectDb.isConnected(5, 3));     } So whe...

Popular posts from this blog

The WeakReference class, monitoring memory leak and garbage collection in a Java application

Simplescalar Simulator - Part 2: sim-outorder.c

Notes on Java Performance