public class Binaaripuut {
    public static long laske(int n) {
        long[] tulos = new long[n+1];
        tulos[0] = 1;
        for (int i = 1; i <= n; i++) {
            for (int j = 0; j < i; j++) {
                tulos[i] += tulos[j]*tulos[i-1-j];
            }
        }
        return tulos[n];
    }

    public static void main(String[] args) {
        System.out.println(laske(30));
    }
}
