Algorithms_in_C  1.0.0
Set of algorithms implemented in C.
sol1.c File Reference

Problem 15 solution More...

#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
Include dependency graph for sol1.c:

Functions

unsigned long long number_of_paths (int N)
 
int main (int argc, char **argv)
 

Detailed Description

Problem 15 solution

Author
Krishna Vedala

Function Documentation

◆ main()

int main ( int  argc,
char **  argv 
)

Main function

31 {
32  int N = 20;
33 
34  if (argc == 2)
35  N = atoi(argv[1]);
36 
37  printf("Number of ways to traverse diagonal of %dx%d grid = %llu\n", N, N,
39 
40  return 0;
41 }
Here is the call graph for this function:

◆ number_of_paths()

unsigned long long number_of_paths ( int  N)

At every node, there are 2 possible ways to move -> down or right. Since it is a square grid, there are in all, 2N steps with N down and N right options, without preference for order. Hence, the path can be be traced in N out of 2N number of ways. This is the same as binomial coeeficient.

18 {
19  unsigned long long path = 1;
20  for (int i = 0; i < N; i++)
21  {
22  path *= (N << 1) - i;
23  path /= i + 1;
24  }
25 
26  return path;
27 }
N
#define N
Definition: sol1.c:109
number_of_paths
unsigned long long number_of_paths(int N)
Definition: sol1.c:17