ADA Lab Manual Updated 2023-24
ADA Lab Manual Updated 2023-24
[UPDATED 2023-24]
SEMESTER :IV
TOCE
Mission
“The department aims to develop the best information science professionals who
work creatively, communicate effectively and become technologically competent,
also to mould them into good citizens by inculcating sense of ethical values in
them”
Vision
“To meet the educational, research and service needs of the region through
collaboration with academic and technical institutions, business and government
agencies and cultural organizations, thereby providing a platform that encourages
students and staff to
                                                            INDEX
                                                                                                        PAGE
 S.NO                                           EXPERIMENTS
                                                                                                         NO
           Design and implement C/C++ Program to find Minimum Cost Spanning Tree of a given
1.         connected undirected graph using Kruskal's algorithm.                                          4
           Design and implement C/C++ Program to find Minimum Cost Spanning Tree of a given
2.                                                                                                        6
           connected undirected graph using Prim's algorithm.
           a. Design and implement C/C++ Program to solve All-Pairs Shortest Paths problem using
3.         Floyd's algorithm. b. Design and implement C/C++ Program to find the transitive closure        9
           using Warshal's algorithm.
           Design and implement C/C++ Program to find shortest paths from a given vertex in a
4.                                                                                                        12
           weighted connected graph to other vertices using Dijkstra's algorithm.
           Design and implement C/C++ Program to obtain the Topological ordering of vertices in
5.                                                                                                        15
           a given digraph
           Design and implement C/C++ Program to solve 0/1 Knapsack problem using Dynamic
6.                                                                                                        17
           Programming method.
           Design and implement C/C++ Program to solve discrete Knapsack and continuous
7.                                                                                                        18
           Knapsack problems using greedy approximation method.
           Design and implement C/C++ Program to find a subset of a given set S = {sl , s2,.....,sn}
8.                                                                                                        20
           of n positive integers whose sum is equal to a given positive integer d.
           Design and implement C/C++ Program to sort a given set of n integer elements using
           Selection Sort method and compute its time complexity. Run the program for varied
9.                                                                                                        21
           values of n> 5000 and record the time taken to sort. Plot a graph of the time taken
           versus n. The elements can be read from a file or can be generated using the random
           number generator.
           Design and implement C/C++ Program to sort a given set of n integer elements using
           Quick Sort method and compute its time complexity. Run the program for varied values
10                                                                                                        12
           of n> 5000 and record the time taken to sort. Plot a graph of the time taken versus n.
           The elements can be read from a file or can be generated using the random number
           generator.
           Design and implement C/C++ Program to sort a given set of n integer elements using
           Merge Sort method and compute its time complexity. Run the program for varied
11.        values of n> 5000, and record the time taken to sort. Plot a graph of the time taken           23
           versus n. The elements can be read from a file or can be generated using the random
           number generator.
12         Design and implement C/C++ Program for N Queen's problem using Backtracking.                  24
II         SAMPLE VIVA QUESTIONS AND ANSWERS                                                            26-29
    1. Design and implement C/C++ Program to find Minimum Cost Spanning Tree of a given
       connected undirected graph using Kruskal's algorithm.
Aim : To apply Kruskal's Algorithm for computing the minimum spanning tree is directly based
on the generic MST algorithm. It builds the MST in forest.
Definition: Kruskal’s algorithm is an algorithm in graph theory that finds a minimum spanning tree for a
connected weighted graph. This mean it finds a subset of the edges that forms a tree that includes every
vertex, where the total weight of all the edges in the tree is minimized. If the graph is not connected,
then it finds a minimum spanning forest .It is an example of a greedy algorithm.
Algorithm
Start with an empty set A, and select at every stage the shortest edge that has not been chosen or
rejected, regardless of where this edge is situated in graph.
        If an edge (u, v) connects two different trees, then (u, v) is added to the set of edges of the
         MST, and two trees connected by an edge (u, v) are merged into a single tree.
        On the other hand, if an edge (u, v) connects two vertices in the same tree, then edge (u,
         v) is discarded.
Kruskals algorithm can be implemented using disjoint set data structure or priority queue data
structure.
MST_KRUSKAL (G, w)
    8. UNION (u, v)
    9. Return A
Program:
#include<stdio.h>
#define INF 999
#define MAX 100
int p[MAX],c[MAX][MAX],t[MAX][2];
int find(int v)
{
         while(p[v])
         v=p[v];
         return v;
}
void kruskal(int n)
{
        int i,j,k,u,v,min,res1,res2,sum=0;
        for(k=1;k<n;k++)
        {
                   min=INF;
                   for(i=1;i<n-1;i++)
                   {
                            for(j=1;j<=n;j++)
                            {
                                     if(i==j)continue;
                                     if(c[i][j]<min)
                                     {
                                     u=find(i);
                                                v=find(j);
                                                if(u!=v)
                                                {
                                                         res1=i;
                                                         res2=j;
                                                         min=c[i][j];
                                                }
                                     }
                            }
                   }
                   union1(res1,find(res2));
                t[k][1]=res1;
                t[k][2]=res2;
                sum=sum+min;
        }
        printf("\nCost of spanning tree is=%d",sum);
        printf("\nEdgesof spanning tree are:\n");
        for(i=1;i<n;i++)
        printf("%d -> %d\n",t[i][1],t[i][2]);
}
int main()
{
        int i,j,n;
        printf("\nEnter the n value:");
        scanf("%d",&n);
        for(i=1;i<=n;i++)
        p[i]=0;
        printf("\nEnter the graph data:\n");
        for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
        scanf("%d",&c[i][j]);
        kruskal(n);
        return 0;
}
Input/Output:
Enter the n value:5
Enter the graph data:
0 10 15 9 999
10 0 999 17 15
15 999 0 20 999
9 17 20 0 18
999 15 999 18 0
Cost of spanning tree is=49
Aim:To find minimum spanning tree of a given graph using prim’s algorithm
Definition: Prim’s is an algorithm that finds a minimum spanning tree for a connected weighted
undirected graph. This means it finds a subset of the edges that forms a tree that includes every vertex,
where the total weight of all edges in the tree is minimized. Prim’s algorithm is an example of a greedy
algorithm.
Algorithm
MST_PRIM (G, w, v)
    1. Q ← V[G]
    2. for each u in Q do
    3.   key [u] ← ∞
    4. key [r] ← 0
    5. π[r] ← NIl
    6. while queue is not empty do
    7.   u ← EXTRACT_MIN (Q)
    8.   for each v in Adj[u] do
    9.      if v is in Q and w(u, v) < key [v]
    10.        then π[v] ← w(u, v)
    11.           key [v] ← w(u, v)
Analysis
The performance of Prim's algorithm depends of how we choose to implement the priority queue
Q.
Program:
#include<stdio.h>
// #include<conio.h>
#define INF 999
               {
                         min=d[j];
                         u=j;
               }
               v[u]=1;
               sum=sum+d[u];
               printf("\n%d -> %d sum=%d",ver[u],u,sum);
               for(j=1;j<=n;j++)
               if(v[j]==0 && c[u][j]<d[j])
               {
                        d[j]=c[u][j];
                        ver[j]=u;
               }
       }
       return sum;
}
void main()
{
       int c[10][10],i,j,res,s,n;
       clrscr();
       printf("\nEnter n value:");
       scanf("%d",&n);
       printf("\nEnter the graph data:\n");
       for(i=1;i<=n;i++)
       for(j=1;j<=n;j++)
       scanf("%d",&c[i][j]);
       printf("\nEnter the souce node:");
       scanf("%d",&s);
       res=prim(c,n,s);
       printf("\nCost=%d",res);
       getch();
}
Input/output:
Enter n value:3
Enter the graph data:
0 10 1
10 0 6
160
Enter the souce node:1
1 -> 3 sum=1
3 -> 2 sum=7
Cost=7
Program 3
a. Design and implement C/C++ Program to solve All-Pairs Shortest Paths problem using Floyd's
algorithm. b. Design and implement C/C++ Program to find the transitive closure using Warshal's
algorithm.
Definition: The Floyd algorithm is a graph analysis algorithm for finding shortest paths in a weighted
graph (with positive or negative edge weights). A single execution of the algorithm will find the lengths
(summed weights) of the shortest paths between all pairs of vertices though it does not return details of
the paths themselves. The algorithm is an example of dynamic programming
Algorithm:
Floyd’s Algorithm
Accept no .of vertices
Call graph function to read weighted graph // w(i,j)
Set D[ ] <- weighted graph matrix // get D {d(i,j)} for k=0
// If there is a cycle in graph, abort. How to find?
Repeat for k = 1 to n
                   Repeat for i = 1 to n
                      Repeat for j = 1 to n
                            D[i,j] = min {D[i,j], D[i,k] + D[k,j]}
Print D
Program A:
#include<stdio.h>
#include<conio.h>
#define INF 999
void main()
{
       int a[10][10],n,i,j;
       clrscr();
       printf("\nEnter the n value:");
       scanf("%d",&n);
       printf("\nEnter the graph data:\n");
       for(i=1;i<=n;i++)
       for(j=1;j<=n;j++)
       scanf("%d",&a[i][j]);
         floyd(a,n);
         printf("\nShortest path matrix\n");
         for(i=1;i<=n;i++)
         {
                  for(j=1;j<=n;j++)
                  printf("%d ",a[i][j]);
                  printf("\n");
         }
         getch();
}
Input/Output:
Enter the n value:4
Enter the graph data:
0 999 3 999
2 0 999 999
999 7 0 1
6 999 999 0
Shortest path matrix
0 10 3 4
2056
7701
6 16 9 0
Definition:The Floyd-Warshall algorithm is a graph analysis algorithm for finding shortest paths in a
weighted graph. A single execution of the algorithm will find the lengths of the shortest path between all
pairs of vertices though it does not return details of the paths themselves. The algorithm is an example
of Dynamic programming.
Algorithm
//Input: Adjacency matrix of digraph
//Output: R, transitive closure of digraph
Accept no .of vertices
Call graph function to read directed graph
Set R[ ] <- digraph matrix // get R {r(i,j)} for k=0
Print digraph
Repeat for k = 1 to n
                  Repeat for i = 1 to n
                    Repeat for j = 1 to n
                           R(i,j) = 1 if
                       {rij(k-1) = 1 OR
                                      rik(k-1) = 1 and rkj(k-1) = 1}
Print R
Program:
#include<stdio.h>
void warsh(int p[][10],int n)
{
        int i,j,k;
        for(k=1;k<=n;k++)
        for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
        p[i][j]=p[i][j] || p[i][k] && p[k][j];
}
int main()
{
        int a[10][10],n,i,j;
        printf("\nEnter the n value:");
        scanf("%d",&n);
        printf("\nEnter the graph data:\n");
        for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
        scanf("%d",&a[i][j]);
        warsh(a,n);
        printf("\nResultant path matrix\n");
        for(i=1;i<=n;i++)
        {
                 for(j=1;j<=n;j++)
                 printf("%d ",a[i][j]);
                 printf("\n");
        }
        return 0;
        }
Input/Output:
Enter the n value:4
Enter the graph data:
0100
0001
0000
1010
Resultant path matrix
1111
1111
0000
1111
Program 4 Design and implement C/C++ Program to find shortest paths from a given vertex in a
weighted connected graph to other vertices using Dijkstra's algorithm.
Aim:To find shortest path using Dijikstra’s algorithm.
Definition: Dijikstra’s algorithm -For a given source vertex(node) in the graph, the algorithm finds the
path with lowest cost between that vertex and every other vertex. It can also be used for finding cost of
shortest paths from a single vertex to a single destination vertex by stopping the algorithm once the
shortest path to the destination vertex has been determined.
                    2
Efficiency:1)        )-graph represented by weighted matrix and priority queue as unordered array
2)O(│E│log│v│)-graph represented by adjacency lists and priority queue as min-heap
Algorithm: Dijikstra(G,s)
//Dijikstra’s algorithm for single source shortest path
//input:A weighted connected graph with non negative weights and its vertex s
//output:The length dv of a shortest path from s to v and penultimate vertex pv for every vertex v in V
Initialize(Q)
for every vertex v in V do
dv<-∞;Pv<-null
Insert(Q,v,dv)
Ds<-0; Decrease(Q,s,ds);VT<-ǿ
for i<- 0 to │V│-1 do
u*<-DeleteMin(Q)
VT<-VT U{u*}
For every vertex u in V-VT that is adjacent to u* do
If du*+w(u*,u)<du
du<- du*+w(u*,u); pu<-u*
Decrease(Q,u,du)
Program:
#include<stdio.h>
#define INF 999
void dijkstra(int c[10][10],int n,int s,int d[10])
{
        int v[10],min,u,i,j;
        for(i=1;i<=n;i++)
        {
                 d[i]=c[s][i];
                 v[i]=0;
        }
        v[s]=1;
        for(i=1;i<=n;i++)
        {
                 min=INF;
                 for(j=1;j<=n;j++)
                 if(v[j]==0 && d[j]<min)
                 {
                          min=d[j];
                          u=j;
                 }
                 v[u]=1;
                 for(j=1;j<=n;j++)
                 if(v[j]==0 && (d[u]+c[u][j])<d[j])
                 d[j]=d[u]+c[u][j];
        }
}
int main()
{
          int c[10][10],d[10],i,j,s,sum,n;
          printf("\nEnter n value:");
          scanf("%d",&n);
          printf("\nEnter the graph data:\n");
          for(i=1;i<=n;i++)
          for(j=1;j<=n;j++)
          scanf("%d",&c[i][j]);
          printf("\nEnter the souce node:");
          scanf("%d",&s);
          dijkstra(c,n,s,d);
          for(i=1;i<=n;i++)
          printf("\nShortest distance from %d to %d is %d",s,i,d[i]);
    return 0;
}
Input/Output
Enter n value:6
Enter the graph data:
0 15 10 999 45 999
999 0 15 999 20 999
20 999 0 20 999 999
999 10 999 0 35 999
999 999 999 30 0 999
999 999 999 4 999 0
Enter the souce node:2
Shortest distance from 2 to 1 is 35
Shortest distance from 2 to 2 is 0
Shortest distance from 2 to 3 is 15
Shortest distance from 2 to 4 is 35
Shortest distance from 2 to 5 is 20
Shortest distance from 2 to 6 is 999
Output:
enter the no. of nodes:
6
enter the cost adjacency matrix,'9999' for no direct path
0 15 10 9999 45 9999
9999 0 15 9999 20 9999
20 9999 0 20 9999 9999
9999 10 9999 0   35 9999
9999 9999 9999 30 0 9999
9999 9999 9999 4  9999 0
6->1=49
6->2=14
6->3=29
6->4=4
6->5=34
6->6=0
Program 5 Design and implement C/C++ Program to obtain the Topological ordering of vertices in a
given digraph
Aim:To find topological ordering of given graph
Definition:Topological ordering that for every edge in the graph,the vertex where the edge
starts is listed before the edge where the edge ends.
Algorithm:
1.repeatedly identify in a remaining digraph a source which is a vertex with no incoming
edges and delete it along with all edges outgoing from it
2.Thje order in which the vertices are deleted yields a solution to the topological sorting.
#include<stdio.h>
// #include<conio.h>
int temp[10],k=0;
void sort(int a[][10],int id[],int n)
{
int i,j;
for(i=1;i<=n;i++)
{
if(id[i]==0)
{
id[i]=-1;
temp[++k]=i;
for(j=1;j<=n;j++)
{
if(a[i][j]==1 && id[j]!=-1)
id[j]--;
}
i=0;}}}
void main()
{
int a[10][10],id[10],n,i,j;
// clrscr();
Input/output:
Enter the n value:6
Enter the graph data:
001100
000110
000101
000001
000001
000000
Topological ordering is:1 2 3 4 5 6
Program 6 Design and implement C/C++ Program to solve 0/1 Knapsack problem using Dynamic
Programming method.
Aim: To implement 0/1 Knapsack problem using Dynamic programming
ALGORITHM
PROGRAM:
#include<stdio.h>
int w[10],p[10],n;
Input/Output:
Enter the no. of objects:4
Here's a simplified version of the C program to solve discrete Knapsack and continuous Knapsack
problems using the greedy approximation method:
#include <stdio.h>
#define MAX 50
         temp2 = p[i];
         p[i] = p[j];
         p[j] = temp2;
            }
        }
    }
    int currentWeight = 0;
    maxprofit = 0.0;
int main() {
  printf("Enter the number of objects: ");
  scanf("%d", &n);
greedyKnapsack(n, w, p, m);
    return 0;
}
Program 8 Design and implement C/C++ Program to find a subset of a given set S = {sl , s2,.....,sn} of n
positive integers whose sum is equal to a given positive integer d.
AIM: An instance of the Subset Sum problem is a pair (S, t), where S = {x1, x2, ..., xn} is a set of positive
integers and t (the target) is a positive integer. The decision problem asks for a subset of S whose sum is
as large as possible, but not larger than t.
Algorithm: SumOfSub (s, k, r)
//Values of x[ j ], 1 <= j < k, have been determined
//Node creation at level k taking place: also call for creation at level K+1 if possible
// s = sum of 1 to k-1 elements and r is sum of k to n elements
//generating left child that means including k in solution
Set x[k] = 1
If (s + s[k] = d) then subset found, print solution
If (s + s[k] + s[k+1] <=d)
       then SumOfSum (s + s[k], k+1, r – s[k])
//Generate right child i.e. element k absent
If (s + r - s[k] >=d) AND (s + s[k+1] )<=d
THEN { x[k]=0;
       SumOfSub(s, k+1, r – s[k])
Program:
 #include<stdio.h>
// #include<conio.h>
#define MAX 10
int s[MAX],x[MAX],d;
void sumofsub(int p,int k,int r)
{
         int i;
         x[k]=1;
         if((p+s[k])==d)
         {
                  for(i=1;i<=k;i++)
                  if(x[i]==1)
                  printf("%d ",s[i]);
                  printf("\n");
         }
         else
         if(p+s[k]+s[k+1]<=d)
         sumofsub(p+s[k],k+1,r-s[k]);
         if((p+r-s[k]>=d) && (p+s[k+1]<=d))
         {
                  x[k]=0;
                  sumofsub(p,k+1,r-s[k]);
         }
}
int main()
{
        int i,n,sum=0;
        printf("\nEnter the n value:");
        scanf("%d",&n);
        printf("\nEnter the set in increasing order:");
        for(i=1;i<=n;i++)
        scanf("%d",&s[i]);
        printf("\nEnter the max subset value:");
        scanf("%d",&d);
        for(i=1;i<=n;i++)
        sum=sum+s[i];
        if(sum<d || s[1]>d)
        printf("\nNo subset possible");
        else
        sumofsub(0,1,sum);
        return 0;
}
Input/output:
Enter the n value:9
Enter the set in increasing order:1 2 3 4 5 6 7 8 9
Enter the max subset value:9
126
135
18
234
27
36
45
9
Program 9 Design and implement C/C++ Program to sort a given set of n integer elements using
Selection Sort method and compute its time complexity. Run the program for varied values of n> 5000
and record the time taken to sort. Plot a graph of the time taken versus n. The elements can be read
from a file or can be generated using the random number generator.
Aim: Sort a given set of elements using Selection sort and determine the time required to sort elements.
Repeat the experiment for different values of n, the number of elements in the list to be sorted and plot
a graph of the time taken versus n.
Definition: selection sort is a sorting routine that scans a list of items repeatedly and, on each pass,
selects the item with the lowest value and places it in its final position. It is based on brute force
approach. Sequential search is a Θ(n2) algorithm on all inputs.
Algorithm:
SelectionSort(A[0…n-1])
//sort a given array by select5ion sort
//input:A[0…n-1]of orderable elements
Output:Array a[0…n-1] Sorted in ascending order
        for(i=0;i<n;i++)
        printf("%d ",a[i]);
        getch();
}
Input /output:
Enter the n value:5
Enter the array:10 2 3 15 12
Time taken is:0.109890
Sorted array is:2 3 10 12 15
Program 10 Design and implement C/C++ Program to sort a given set of n integer elements using
Quick Sort method and compute its time complexity. Run the program for varied values of n> 5000 and
record the time taken to sort. Plot a graph of the time taken versus n. The elements can be read from a
file or can be generated using the random number generator.
Aim:
     The aim of this program is to sort ‘n’ randomly generated elements using Quick sort and Plotting
the graph of the time taken to sort n elements versus n.
Definition: Quick sort is based on the Divide and conquer approach. Quick sort divides array according
to their value. Partition is the situation where all the elements before some position s are smaller than
or equal to A[s] and all the elements after position s are greater than or equal to A[s].
Efficiency: Cbest(n) Є Θ(nlog2n),Cworst(n) ЄΘ(n2),Cavg(n)Є1.38nlog2n
 Algorithm: Quick sort (A[l….r])
    // Sorts a sub array by quick sort
    //Input : A sub array A[l..r] of A[0..n-1] ,defined by its left and right indices l
   //and r
   // Output : The sub array A[l..r] sorted in non decreasing order
          if l < r
             s = Partition (A[l..r]) //s is a split position
             Quick sort (A[l …s-1])
             Quick sort (A[s+1…r])
Return j
Program:
#include<stdio.h>
#include<stdlib.h>
#include<sys/time.h>
#include<time.h>
void fnGenRandInput(int [], int);
void fnDispArray( int [], int);
int fnPartition(int [], int , int );
void fnQuickSort(int [], int , int );
inline void fnSwap(int*, int*);
inline void fnSwap(int *a, int *b)
{
int t = *a; *a = *b; *b = t;
}
/
**********************************************************************
********
*Function
: main
*Input parameters:
*
int argc - no of commamd line arguments
*
char **argv - vector to store command line argumennts
*RETURNS
:
0 on success
**********************************************************************
********/
int main( int argc, char **argv)
{
FILE *fp;
struct timeval tv;
double dStart,dEnd;
int iaArr[500000],iNum,iPos,iKey,i,iChoice;
for(;;)
{
printf("\n1.Plot the Graph\n2.QuickSort\n3.Exit");
printf("\nEnter your choice\n");
scanf("%d",&iChoice);
switch(iChoice)
{
case 1:
fp = fopen("QuickPlot.dat","w");
for(i=100;i<100000;i+=100)
{
fnGenRandInput(iaArr,i);
gettimeofday(&tv,NULL);
dStart = tv.tv_sec + (tv.tv_usec/1000000.0);
fnQuickSort(iaArr,0,i-1);
gettimeofday(&tv,NULL);
dEnd = tv.tv_sec + (tv.tv_usec/1000000.0);
fprintf(fp,"%d\t%lf\n",i,dEnd-dStart);
}
fclose(fp);
printf("\nData File generated and stored in file < QuickPlot.dat >.\n
Use a plotting utility\n");
break;
case 2:
printf("\nEnter the number of elements to sort\n");
scanf("%d",&iNum);
printf("\nUnsorted Array\n");
fnGenRandInput(iaArr,iNum);
fnDispArray(iaArr,iNum);
fnQuickSort(iaArr,0,iNum-1);
printf("\nSorted Array\n");
fnDispArray(iaArr,iNum);
break;
case 3:
exit(0);
}
}
return 0;
}
/
**********************************************************************
********
*Function
: fnPartition
*Description
: Function to partition an iaArray using First element as Pivot
*Input parameters:
*
int a[] - iaArray to hold integers
*
int l
- start index of the subiaArray to be sorted
*
int r
- end index of the subiaArray to be sorted
*RETURNS
: integer value specifying the location of partition
**********************************************************************
********/
int fnPartition(int a[], int l, int r)
{
int i,j,temp;
int p;
p = a[l];
i = l;
j = r+1;
do
{
do { i++; } while (a[i] < p);
do { j--; } while (a[j] > p);
fnSwap(&a[i], &a[j]);
}
while (i<j);
fnSwap(&a[i], &a[j]);
fnSwap(&a[l], &a[j]);
return j;
}
/
**********************************************************************
********
*Function
: fnQuickSort
*Description
: Function to sort elements in an iaArray using Quick Sort
*Input parameters:
*
int a[] - iaArray to hold integers
*
int l
- start index of the subiaArray to be sorted
*
int r
- end index of the subiaArray to be sorted
*RETURNS
: no value
**********************************************************************
******/
void fnQuickSort(int a[], int l, int r)
{
int s;
if (l < r)
{
s = fnPartition(a, l, r);
fnQuickSort(a, l, s-1);
fnQuickSort(a, s+1, r);
}
}
/
**********************************************************************
********
*Function
: GenRandInput
*Description
: Function to generate a fixed number of random elements
*Input parameters:
*
Quick.gpl
iselab@cselab-B85M-DS3H:~/Desktop/sample$ ls
  741
 2059
 5247
 6997
 7150
 7327
 7506
 8915
 9867
 9897
QuickPlot.png
QuickPlot.dat
In the .dat file we have 99900 0.012101 random values incremented for every 100.
Program 11 Design and implement C/C++ Program to sort a given set of n integer elements using
Merge Sort method and compute its time complexity. Run the program for varied values of n> 5000, and
record the time taken to sort. Plot a graph of the time taken versus n. The elements can be read from a
file or can be generated using the random number generator.
Aim:
    The aim of this program is to sort ‘n’ randomly generated elements using Merge sort and Plotting
the graph of the time taken to sort n elements versus n.
Definition: Merge sort is a sort algorithm based on divide and conquer technique. It divides the array
element based on the position in the array. The concept is that we first break the list into two smaller
lists of roughly the same size, and then use merge sort recursively on the subproblems, until they cannot
subdivide anymore. Then, we can merge by stepping through the lists in linear time. Its time efficiency is
Θ(n log n).
Algorithm: Merge sort (A[0…n-1]
        // Sorts array A[0..n-1] by Recursive merge sort
       // Input : An array A[0..n-1] elements
      // Output : Array A[0..n-1] sorted in non decreasing order
         If n > 1
           Copy A[0…(n/2)-1] to B[0…(n/2)-1]
           Copy A[0…(n/2)-1] to C[0…(n/2)-1]
           Mergesort (B[0…(n/2)-1])
           Mergesort (C[0…(n/2)-1])
           Merge(B,C,A)
    double dStart,dEnd;
    int iaArr[500000],iNum,iPos,iKey,i,iChoice;
    for(;;)
    {
        printf("\n1.Plot the Graph\n2.MergeSort\n3.Exit");
        printf("\nEnter your choice\n");
        scanf("%d",&iChoice);
        switch(iChoice)
        {
             case 1:
                 fp = fopen("MergePlot.dat","w"); // to find order of
growth for x axis, it create
                 for(i=100;i<100000;i+=100)
                 {
            fnGenRandInput(iaArr,i);// hold up to 5lac values
          gettimeofday(&tv,NULL); // precision up to microsec,
available in header file <sys/time.h> with struct in terminal: give
man gettimeofday,
    for(i=0;i<n;i++)
    {
        X[i] = rand()%10000;// defined in stdlib, pseuodo random no
generating sequence-random like
    }
}
     int i;
     for(i=0;i<n;i++)
     printf(" %5d \n",X[i]);
}
MergePlot.gpl
github.com/fsmk/CS-VTU-Lab-Manual
git clone https://github.com/fsmk/CS-VTU-Lab-Manual.git
Program 12 Design and implement C/C++ Program for N Queen's problem using Backtracking.
Algorithm:
/* outputs all possible acceptable positions of n queens on n x n chessboard */
// Initialize x [ ] to zero
// Set k = 1 start with first queen
Repeat for i = 1 to n // try all columns one by one for kth queen
if Place (k, i) true then
    {
            x(k) = i // place kth queen in column i
          if (k=n) all queens placed and hence print output (x[ ])
           else NQueens(K+1,n) //try for next queen
           }
Place (k,i)
/* finds if kth queen in kth row can be placed in column i or not; returns true if queen can be placed */
// x[1,2, . . . k-1] have been defined
//queens at (p, q) & (r, s) attack if |p-r| = |q-s|
Repeat for j = 1 to (k-1)
                     if any earlier jth queen is in ith column ( x[j]= i)
or in same diagonal ( abs(x[ j] - i) = abs( j - k) )
     then kth queen cannot be placed (return false)
return true (as all positions checked and no objection)
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#define MAX 50
        int i,j;
        char cb[10][10];
        for(i=0;i<n;i++)
        for(j=0;j<n;j++)
        cb[i][j]='-';
        for(i=0;i<n;i++)
        cb[i][c[i]]='Q';
        for(i=0;i<n;i++)
        {
                  for(j=0;j<n;j++)
                  printf("%c",cb[i][j]);
                  printf("\n");
        }
}
void n_queens(int n)
{
        int r;
        int c[MAX];
        c[0]=-1;
        r=0;
        while(r>=0)
        {        c[r]++;
                 while(c[r]<n && !can_place(c,r))
                 c[r]++;
                 if(c[r]<n)
                 {        if(r==n-1)
                          {        display(c,n);
                                   printf("\n\n");
                          }
                          else
                          {        r++;
                                   c[r]=-1;
                          }
                 }
                 else
                 r--;
        }
}
void main()
{
       int n;
       clrscr();
       printf("\nEnter the no. of queens:");
       scanf("%d",&n);
       n_queens(n);
       getch();
}
Input/Output:
Enter the no. of queens:4
-Q--
---Q
Q---
--Q-
--Q-
Q---
---Q
-Q—
An algorithm is a well-defined computational procedure that take some value as input and
generate some value as output. In simple words, it’s a sequence of computational steps that
converts input into the output.
Time complexity of an algorithm indicates the total time needed by the program to run to
completion. It is usually expressed by using the big O notation.
9) The complexity of three algorithms is given as: O(n), O(n2) and O(n3). Which should
execute slowest for large value of n?
All will execute in same time.
10) In quick sort, the number of partitions into which the file of size n is divided by a
selected record is 2.
The three factors contributing to the sort efficiency considerations are the efficiency in
coding, machine run time and the space requirement for running the procedure.
11) How many passes are required to sort a file of size n by bubble sort method?
        N-1
12) How many number of comparisons are required in insertion sort to sort a file if the file
is sorted in reverse order?
A. N2
13) How many number of comparisons are required in insertion sort to sort a file if the file
is already sorted?                                                            N-1
14) In quick sort, the number of partitions into which the file of size n is divided by a
selected record is 2
15) The worst-case time complexity of Quick Sort is________.O(n2)
18)The algorithm like Quick sort does not require extra memory for carrying out the
sorting procedure. This technique is called __________.in-place
23) A sort which compares adjacent elements in a list and switches where necessary is ____.
    A. insertion sort
24) The correct order of the efficiency of the following sorting algorithms according to their
overall running time comparison is
bubble>selection>insertion
25) The total number of comparisons made in quick sort for sorting a file of size n, is
A. O(n log n)
27)For the improvement of efficiency of quick sort the pivot can be ______________.
“the mean element”
38). Specify the algorithms used for constructing Minimum cost spanning tree.
a) Prim’s Algorithm
b) Kruskal’s Algorithm
39). State single source shortest path algorithm (Dijkstra’s algorithm).
For a given vertex called the source in a weigted connected graph,find shotrtest paths to all its
other vertices.Dijikstra’s algorithm applies to graph with non-negative weights only.
40). State efficiency of prim’s algorithm.
O(|v|2) (WEIGHT MATRIX AND PRIORITY QUEUE AS UNORDERED ARRAY)
O(|E| LOG|V|) (ADJACENCY LIST AND PRIORITY QUEUE AS MIN-HEAP)
41) State Kruskal Algorithm.
The algorithm looks at a MST for a weighted connected graph as an acyclic subgraph with |v|-1
edges for which the sum of edge weights is the smallest.
42) State efficiency of Dijkstra’s algorithm.
O(|v|2) (WEIGHT MATRIX AND PRIORITY QUEUE AS UNORDERED ARRAY)