KEMBAR78
Daa Lab Manual Program 2021-2022 | PDF | Mathematical Relations | Theoretical Computer Science
0% found this document useful (0 votes)
1K views47 pages

Daa Lab Manual Program 2021-2022

The document describes algorithms for finding a minimum spanning tree of a graph using Prim's and Kruskal's algorithms. Prim's algorithm starts at a node and grows the tree by adding the lowest cost edge that connects an unreached node. Kruskal's algorithm sorts the edges by cost and builds the tree by adding edges as long as they do not create cycles. Pseudocode and C programs are provided to implement the algorithms. The output shows a minimum spanning tree was generated for a given graph using the greedy methods.

Uploaded by

UMA SIKAMANI
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
1K views47 pages

Daa Lab Manual Program 2021-2022

The document describes algorithms for finding a minimum spanning tree of a graph using Prim's and Kruskal's algorithms. Prim's algorithm starts at a node and grows the tree by adding the lowest cost edge that connects an unreached node. Kruskal's algorithm sorts the edges by cost and builds the tree by adding edges as long as they do not create cycles. Pseudocode and C programs are provided to implement the algorithms. The output shows a minimum spanning tree was generated for a given graph using the greedy methods.

Uploaded by

UMA SIKAMANI
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 47

Ex.

No : 1
Date :

DIVIDE-AND-CONQUER WITH RECURSIVE FUNCTION

Aim :
To search an element in a given array using binary search recursive technique.

Algorithm :

Input : Array A, Target : Key is the number to be searched in the


list of elements.

1. Initialize start index as low =0 and end index as high = n-1


2. At each step,we find mid value in the search space and compare it
with target value. There are three cases possible:
3. CASE 1: If target is equal to middle, then return mid.
4. CASE 2: If target is less than middle i.e target<A[mid],we discard all
the elements in the right search space including mid element. Now
new high would be mid-1 while 'low' remains as it is.
5. CASE 3: If the target element is greater than middle
i.e target>A[mid],we discard all the elements in the left search space
including mid element. Now new low would be mid+1 while 'high'
remains as it is.

Program :

#include<iostream.h>

#include<conio.h>

intbinsear(int l[], int x, int first, int last)

int middle;

if (last >= first)


1
{

middle = (first + last)/2;

if(x==l[middle])

return middle;

else if (x < l[middle])

return binsear(l,x,first,middle-1);

else

return binsear(l,x,middle+1,last);

return -1;

void main()

clrscr();

intarr[20],n,i,pos,x,s,e,result;

cout<<"Enter the total number of elements in array";

cin>>n;

cout<<"Enter the elements";

for(i=0;i<n;i++)

cin>>arr[i];

cout<<"enter the element to be searched ";

cin>>x;

s=0;

e=n-1;
2
result = binsear(arr,x,s,e);

if(result >= 0)

cout<<" Element"<< " "<< x<<" found at the index position "<< result;

else

cout<<"element not found";

getch();

Output :

Result :

The given number was searched and it was found in the given array using
binary search recursive technique.

3
Ex.No : 2
Date :

DIVIDE-AND-CONQUER WITH NON-RECURSIVE FUNCTION

Aim :
To search an element in a given array using binary search iterative technique.

Algorithm :

Input : An Array A, Key is the number to be searched in the list of elements.

1. Inside the while loop, "mid" is obtained by calculating (low+high)/2.

2. If number at position mid equal to key or target element then the control
returns index of mid element by printing that the number has been found
along with the index at which it was found.
*Else, if key or target is less than number at position mid then the portion of
the Array from the mid upwards is removed from contention by making
"high" equal to mid-1.

3. Else, it implies that key element is greater than number at position mid(as it
is not less than and also not equal, hence, it has to be greater). Hence, the
portion of the list from mid and downwards is removed from contention by
making "low" equal to mid+1.

4. The while loop continues to iterate in this way till either the element is
returned (indicating key has been found in the Array) or low becomes greater
than high,in which case -1 is returned indicating that key could not be found
and the same is printed as output.

4
Program :

#include <iostream.h>

int binsear(int a[],int n,int x)

int low=0, high=n-1;

while(low<=high)

int mid = (low+high)/2;

if(x==a[mid])

return mid;

else

if(x<a[mid])

high=mid-1;

else

low=mid+1;

return -1;

int main(void)

{
5
int a[10],n,target;

cin>>n;

for(int i=0;i<n;i++)

cin>>a[i];

cout<<"element to search";

cin>>target;

int index =binsear(a,n,target);

if (index != -1)

cout<<"element at index"<<index;

else

cout<<"element not found";

return 0;

6
Output :

Result :

The given number was searched and it was found in the given array using
binary search iterative technique.

7
Ex.No : 3
Date :
STRASSEN’S MATRIX MULTIPLICATION

Aim :

To multiply two matrices using Strassen’s formula

Algorithm :

The advantage of Strassen’s algorithm is, that it uses less number of


operations than the naive method. It uses divide and conquer strategy, and thus,
divides the square matrix of size n to n/2. It reduces the 8 recursive calls to 7.

Logic:

Divide the matrix, then use the Strassen’s formulae:

p=(a11+a22)*(b11+b22);

q=(a21+a22)*b11;

r=a11*(b12-b22);

s=a22*(b21-b11);

t=(a11+a12)*b22;

u=(a11-a21)*(b11+b12);

v=(a12-a22)*(b21+b22);

For two 2×2 matrices a and b, where,

A=

a11 a12

a21 a22

8
B=

b11 b12

b21 b22

Multiplied matrix will have

C=

p+s-t+v r+t

q+s p+r-q+u

Steps :

1. Input the no. rows and columns of both the elements


2. Check ifthe number of columns of first matrix is same as the rows of
second matrix(condition for matrix multiplication).
3. Use the strassen’s formulae.
4. Feeding the values in the final matrix.
5. Next, we display the final matrix.

Program :

#include<iostream.h>

double a[4][4];

double b[4][4];

void insert(double x[4][4])

double val;

for(int i=0;i<4;i++)

for(int j=0;j<4;j++)
9
{

cin>>val;

x[i][j]=val;

double cal11(double x[4][4])

return (x[1][1] * x[1][2])+ (x[1][2] * x[2][1]);

double cal21(double x[4][4])

return (x[3][1] * x[4][2])+ (x[3][2] * x[4][1]);

double cal12(double x[4][4])

return (x[1][3] * x[2][4])+ (x[1][4] * x[2][3]);

double cal22(double x[4][4])

return (x[2][3] * x[1][4])+ (x[2][4] * x[1][3]);

int main()

double a11,a12,a22,a21,b11,b12,b21,b22,a[4][4],b[4][4];

double p,q,r,s,t,u,v,c11,c12,c21,c22;
10
//insert values in the matrix a

cout<<"\n a: \n";

insert(a);

//insert values in the matrix a

cout<<"\n b: \n";

insert(b);

//dividing single 4x4 matrix into four 2x2 matrices

a11=cal11(a);

a12=cal12(a);

a21=cal21(a);

a22=cal22(a);

b11=cal11(b);

b12=cal12(b);

b21=cal21(b);

b22=cal22(b);

//assigning variables according to strassen's algorithm

p=(a11+a22)*(b11+b22);

q=(a21+a22)*b11;

r=a11*(b12-b22);

s=a22*(b21-b11);

t=(a11+a12)*b22;

u=(a11-a21)*(b11+b12);

v=(a12-a22)*(b21+b22);

//output the final matrix

cout<<"\n final matrix";

cout<<"\n"<<p+s-t+v<<" "<<r+t;
11
cout<<"\n"<<q+s<<" "<<p+r-q+u;

return 0;

Output :

a:

1537

4262

7272

9262

b:

5426

4661

5426

7147

Final matrix:

1440 2072

1680 1444

Result :

The given two matrices are multiplied using Strassen’s technique.

12
Ex.No:4.1

Date :

GREEDY METHOD

(MINIMUM COST SPANNING TREE USING PRIM’S ALGORITHM)

Aim:

To find a minimum cost spanning tree for a given graph using Prim’s
Algorithm

Algorithm :

1. Start at any node in the graph

Mark the starting node as reached

Mark all the other nodes in the graph as unreached

Right now, the Minimum cost Spanning Tree (MST)


consists of the starting node

We expand the MST with the procedure given below....

2. Find an edge e with minimum cost in the graph that connects:

A reached node x to an unreached node y

3. Add the edge e found in the previous step to the Minimum cost
Spanning Tree

Mark the unreached node y as reached

4. Repeat the steps 2 and 3 until all nodes in the graph have become
reached

Program:

#include<iostream.h>

#include<conio.h>

int cost[10][10];

inti,j,k,n,top,v,u;

intstk[10], visit[10], visited[10];

13
void main()

intm,c;

clrscr();

cout<<"\n Minimum Cost Spanning Tree using Prim's Algorithm";

cout<<endl;

cout<<"\n Enter number of Vertices : ";

cin>>n;

cout<<"\n Enter Number of Edges :";

cin>>m;

cout<<"\n Edges Cost\n";

for(k=1;k<=m;k++)

cin>>i>>j>>c;

cost[i][j]=c;

for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

if(cost[i][j]==0)

cost[i][j]=31999;

cout<<"\n Order of Visited Vertices : ";

k=1;

while(k<n)

m=31999;

if(k==1)
14
{

for(i=1;i<=n;i++)

for(j=1;j<=m;j++)

if (cost[i][j]<m)

m=cost[i][j];

u=i;

else

for(j=n;j>=1;j--)

if(cost[v][j]<m && visited[j] !=1 && visit[j]!=1)

visit[j]=1;

stk[top]=j;

top++;

m=cost[v][j];

u=j;

cost[v][u]=31999;

v=u;

cout<<v<<" ";

k++;

visit[v]=0;
15
visited[v]=1;

getch();

Output :

Result :

A minimum spanning tree was generated for a given graph and the
output is verified.

16
Ex.No :4.2
Date :
GREEDY METHOD

(MINIMUM COST SPANNING TREE USING KRUSKAL’S


ALGORITHM)

Aim:

To find a minimum cost spanning tree for a given graph using Kruskal’s
Algorithm

Algorithm :

1. Sort all the edges in non-decreasing order of their weight.


2. Pick the smallest edge. Check if it forms a cycle with the spanning tree
formed so far using Union Find data-structure. If cycle is not formed,
include this edge else, discard it.
3. Repeat Step 2 until there are (V-1) edges in the spanning tree.

Program:

#include<iostream.h>

#include<conio.h>

int cost[10][10];

inti,j,k,n,m,c,visit,l,v;

int count,count1,vst,p;

int visited[10];

void main()

int dup1, dup2;

clrscr();

cout<<"\n Minimum Cost Spanning Tree using Kruskal's Algorithm";

cout<<endl;
17
cout<<"\n Enter number of Vertices : ";

cin>>n;

cout<<"\n Enter Number of Edges :";

cin>>m;

cout<<"\n Edges Cost\n";

for(k=1;k<=m;k++)

cin>>i>>j>>c;

cost[i][j]=c;

cost[j][i]=c;

cout<<endl;

for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

if(cost[i][j]==0)

cost[i][j]=31999;

visit =1;

while(visit<n)

v=31999;

for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

if (cost[i][j]!=31999 && cost[i][j]<v && cost[i][j] !=-1)

int count =0;

for(p=1;p<=n;p++)
18
{

if (visited[p]==i || visited[p]==j)

count++;

if (count>=2)

for(p=1;p<=n;p++)

if (cost[i][p] !=31999 && p!=j)

dup1 =p;

for(p=1;p<=n;p++)

if (cost[j][p] !=31999 && p!=i)

dup2=p;

if (cost[dup1][dup2]==-1)

continue;

l=i;

k=j;

v=cost[i][j];

cout<<"Edge from "<<l<<"-->"<<k<<" ";

cost[l][k] = -1;

cost[k][l] =-1;

visit++;

int count =0;

count1 =0;

for(i=1;i<=n;i++)
19
{

if(visited[i]==l)

count++;

if(visited[i]==k)

count1++;

if (count==0)

visited[++vst]=l;

if(count1==0)

visited[++vst]=k;

getch();

Output :

Result :

A minimum spanning tree was generated for a given graph and the
output is verified.
20
Ex.No : 5
Date :
DYNAMIC PROGRAMMING

(0/1 KNAPSACK PROBLEM)

Aim :

To maximise the value inside the knapsack using Dynamic Programming


strategy

Algorithm :

1. In Dynamic Programming(DP) problems, re-computation of same


subproblems can be avoided by constructing a temporary array K[][]
in bottom-up manner.
2. In a DP[][] table let’s consider all the possible weights from ‘1’ to ‘W’
as the columns and weights that can be kept as the rows.
3. The state DP[i][j] will denote maximum value of ‘j-weight’
considering all values from ‘1 to ith’.
4. if we consider ‘wi’ (weight in ‘ith’ row) we can fill it in all columns
which have ‘weight values > wi’.
5. Now two possibilities can take place:
Fill ‘wi’ in the given column.
Do not fill ‘wi’ in the given column.
6. Now we have to take a maximum of these two possibilities, formally if
we do not fill ‘ith’ weight in ‘jth’ column then DP[i][j] state will be
same as DP[i-1][j] but if we fill the weight, DP[i][j] will be equal to
the value of ‘wi’+ value of the column weighing ‘j-wi’ in the previous
row.
7. So we take the maximum of these two possibilities to fill the current
state.

21
Program:

#include<iostream.h>

#include<conio.h>

int max(int a, int b){ return (a>b) ? a:b;}

int knapsack(int W, intwt[], intval[], int n)

inti,w;

int K[50][50];

for(i=0;i<=n; i++)

for(w=0;w<=W;w++)

if (i==0||w==0)

K[i][w]=0;

else if(wt[i-1] <= w)

K[i][w] = max(val[i-1]+K[i-1][w-wt[i-1]],K[i-1][w]);

else

K[i][w] = K[i-1][w];

return K[n][W];

}
22
void main()

intn,W;

clrscr();

cout<<"Enter the number of items in a knapsack: ";

cin>>n;

intval[50],wt[50];

cout<<endl;

for(int i=0;i<n;i++)

cout<<"Enter value and weight for item "<<i<<": ";

cin>>val[i];

cin>>wt[i];

cout<<endl;

cout<<"Enter the knapsack capacity ";

cin>>W;

cout<<endl;

for( i=0;i<n;i++)

cout<<"The value and weight for item "<<i<<": ";

cout<<val[i]<<","<<wt[i];
23
cout<<endl;

cout<<endl;

cout<<"The Knapsack Capacity :"<<W;

cout<<endl;

intks = knapsack(W, wt, val, n);

cout<<"The maximum value that obtained from n items : "<<ks;

getch();

Output :

Result :

Thus the maximum possible value that can be carried in the knapsack is
found successfully and the output is verified.

24
Ex.No :6.1
Date :
SHORTEST PATH PROBLEM

(ALL-PAIRS SHORTEST PATH ALGORITHM)

Aim:

To find shortest distances between every pair of vertices in a given


weighted directed Graph.

Algorithm :

1. We initialize the solution matrix same as the input graph matrix as a first
step. Then we update the solution matrix by considering all vertices as an
intermediate vertex.
2. The idea is to one by one pick all vertices and updates all shortest paths
which include the picked vertex as an intermediate vertex in the shortest
path.
3. When we pick vertex number k as an intermediate vertex, we already
have considered vertices {0, 1, 2, .. k-1} as intermediate vertices.
4. For every pair (i, j) of the source and destination vertices respectively,
there are two possible cases.
a) k is not an intermediate vertex in shortest path from i to j. We keep
the value of dist[i][j] as it is.
b) k is an intermediate vertex in shortest path from i to j. We update the
value of dist[i][j] as dist[i][k] + dist[k][j] if dist[i][j] > dist[i][k] +
dist[k][j]

Program:

#include<iostream.h>

#include<conio.h>

int min(int a, int b);


25
int cost[10][10], a[10][10],i,j,k,c;

void main()

intn,m;

clrscr();

cout<<"Enter the number of vertices";

cin>>n;

cout<<"Enter the number of edges";

cin>>m;

cout<<"Enter the \n Edge cost \n";

for(k=1;k<=m;k++)

cin>>i>>j>>c;

a[i][j] = cost[i][j] =c;

for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

if(a[i][j]==0 && i !=j)

a[i][j] =31999;

for(k=1; k<=n;k++)

for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

a[i][j] = min(a[i][j],a[i][k] +a[k][j]);

cout<<"Resultant Adjacent MAtrix\n";


26
for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

if(a[i][j] != 31999)

cout<<a[i][j]<<" ";

cout<<"\n";

getch();

int min(int a, int b)

if(a<b)

return a;

else

return b;

27
Output :

Result :

The shortest distances between every pair of vertices in a given


weighted directed Graph is obtained and the output is verified.

28
Ex No. 6.2

Date :

SHORTEST PATH PROBLEM

(SINGLE-SOURCE SHORTEST PATH ALGORITHM)

Aim :

To find the shortest path from a single source vertex to all other vertices
in the given graph.

Algorithms :

Given G[][] matrix of graph weight, n no of vertex in graph, u starting


node.

1. Set all vertices distances = infinity except for the source vertex, set the
source distance = 0.

2. Push the source vertex in a min-priority queue in the form (distance ,


vertex), as the comparison in the min-priority queue will be according to
vertices distances.

3.Pop the vertex with the minimum distance from the priority queue (at
first the popped vertex = source).

4.Update the distances of the connected vertices to the popped vertex in


case of "current vertex distance + edge weight < next vertex distance", then
push the vertex with the new distance to the priority queue.

5.If the popped vertex is visited before, just continue without using it.

6.Apply the same algorithm again until the priority queue is empty.

29
Program :

#include <iostream.h>

#define INFINITY 9999

#define max 5

void dijk(int G[max][max],int n, int startnode);

void main()

int G[max][max] =
{{0,1,0,3,10},{1,0,5,0,0},{0,5,0,2,1},{3,0,2,0,6},{10,0,1,6,0}};

int n = 5;

int u = 0;

dijk(G,n,u);

void dijk(int G[max][max],int n, int startnode)

int cost[max][max],distance[max],pred[max];

int visited[max],count,mindistance,nextnode,i,j;

for(i=0;i<n;i++)

for(j=0;j<n;j++)

if (G[i][j] == 0)

cost[i][j] =INFINITY;

else

cost[i][j]=G[i][j];

for(i=0;i<n;i++)

distance[i]=cost[startnode][i];

30
pred[i]=startnode;

visited[i]=0;

distance[startnode]=0;

visited[startnode]=1;

count=1;

while(count<n-1)

mindistance=INFINITY;

for(i=0;i<n;i++)

if(distance[i]<mindistance&&!visited[i])

mindistance=distance[i];

nextnode=i;

visited[nextnode]=1;

for(i=0;i<n;i++)

if(!visited[i])

if(mindistance+cost[nextnode][i]<distance[i])

distance[i]= mindistance + cost[nextnode][i];

pred[i]=nextnode;

count++;

for(i=0;i<n;i++)
31
if (i != startnode)

cout<<"\n Distance of node"<<i<<"="<<distance[i];

cout<<"\nPath="<<i;

j=i;

do

j=pred[j];

cout<<"<-"<<j;

while(j!=startnode);

Output:

G[max][max]={{0,1,0,3,10},

{1,0,5,0,0},

{0,5,0,2,1},

{3,0,2,0,6},

{10,0,1,6,0}}

n=5

u=0

Distance of node1=1

Path=1<-0

Distance of node2=5

Path=2<-3<-0
32
Distance of node3=3

Path=3<-0

Distance of node4=6

Path=4<-2<-3<-0

Result :

The shortest path from a single source vertex to all other vertices in the
given graph is obtained and the output is verified.

33
Ex.No.7

Date :

TRAVELLING SALES PERSON PROBLEM

Aim :

To find the shortest possible route that visits every city exactly once and
returns to the starting point.

Algorithm:

1. we take a subset of the required cities needs to be visited, distance among


the cities and starting city as inputs. Each city is identified by unique
city id like {1,2,3,..n}
2. Initially, all cities are unvisited, and the visit starts from the city .
3. We assume that the initial travelling cost is equal to .
4. Next, the TSP distance value is calculated based on a recursive function.
5. If the number of cities in the subset is two, then the recursive function
returns their distance as a base case.
6. On the other hand, if the number of cities is greater than , then we’ll
calculate the distance from the current city to the nearest city, and the
minimum distance among the remaining cities is calculated recursively.
7. Finally, the algorithm returns the minimum distance as a TSP solution.

Here we use a dynamic approach to calculate the cost function . Using


recursive calls, we calculate the cost function for each subset of the original
problem.

Program :

#include<iostream.h>

int ary[10][10],completed[10],n,cost=0;

void takeInput()

34
{

int i,j;

cout<<"Enter the number of villages: ";

cin>>n;

cout<<"\nEnter the Cost Matrix\n";

for(i=0;i < n;i++)

cout<<"\nEnter Elements of Row: "<<i+1<<"\n";

for( j=0;j < n;j++)

cin>>ary[i][j];

completed[i]=0;

cout<<"\n\nThe cost list is:";

for( i=0;i < n;i++)

cout<<"\n";

for(j=0;j < n;j++)

cout<<"\t"<<ary[i][j];

int least(int c)

int i,nc=999;

int min=999,kmin;

for(i=0;i < n;i++)

{
35
if((ary[c][i]!=0)&&(completed[i]==0))

if(ary[c][i]+ary[i][c] < min)

min=ary[i][0]+ary[c][i];

kmin=ary[c][i];

nc=i;

if(min!=999)

cost+=kmin;

return nc;

void mincost(int city)

int i,ncity;

completed[city]=1;

cout<<city+1<<"--->";

ncity=least(city);

if(ncity==999)

ncity=0;

cout<<ncity+1;

cost+=ary[city][ncity];

return;

mincost(ncity);
36
}

void main()

takeInput();

cout<<"\n\nThe Path is:\n";

mincost(0); //passing 0 because starting vertex

cout<<"\n\nMinimum cost is "<<cost;

Output :

Enter the number of villages: 4

Enter the Cost Matrix

Enter Elements of Row: 1

0413

Enter Elements of Row: 2

4021

Enter Elements of Row: 3

1205

Enter Elements of Row: 4

3150

The cost list is:

0413

4021

1205

3150

37
The Path is:

1—>3—>2—>4—>1

Minimum cost is 7

Result:

A shortest possible route for a travelling sales person was obtained


successfully and the output is verified.

38
Ex.No : 8
Date :
BACKTRACKING

N-QUEENS PROBLEM

Aim :
To find the solution for N-Queens problem using Backtracking

Algorithm :

1) Start in the leftmost column

2) If all queens are placed return true

3) Try all rows in the current column. Do following for every tried row.

a) If the queen can be placed safely in this row then mark this [row,
column] as part of the solution and recursively check if placing queen here
leads to a solution.

b) If placing the queen in [row, column] leads to a solution then return


true.

c) If placing queen doesn't lead to a solution then unmark this [row,


column] (Backtrack) and go to step (a) to try other rows.

4) If all rows have been tried and nothing worked, return false to trigger
backtracking.

Program:

#include<iostream.h>

#include<math.h>

#include<conio.h>

int a[30],count =0;

39
int place(intpos)

int i;

for (i=1;i<pos;i++)

if((a[i] == a[pos]) || ((abs(a[i] - a[pos]) == abs(i-pos))))

return 0;

return 1;

voidprint_sol(int n)

inti,j;

count++;

cout<<endl;

cout<<"Solution "<<count<<"\n";

cout<<endl;

for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

if(a[i]==j)

cout<<"Q\t ";

else

cout<<"*\t ";

}
40
cout<<"\n";

void queen(int n)

int k=1;

a[k]=0;

while(k!=0)

a[k] = a[k]+1;

while((a[k]<=n) && !place(k))

a[k]++;

if(a[k]<=n)

if(k==n)

print_sol(n);

else

k++;

a[k]=0;

else

k--;

}
41
void main()

inti,n;

clrscr();

cout<<"Enter the number of Queens :";

cin>>n;

queen(n);

cout<<endl;

cout<<"Total solutions : "<<count;

getch();

Output :

Result :

The solution for N-Queensproblem is found using Backtracking.

42
Ex.No : 9
Date :
MODULAR ARITHMETIC

Aim :

To compute the GCD of two numbers using modular arithmetic


operations.

Algorithm :

1. Let us use variables m and n to represent two integer numbers and


variable r to represent the remainder of their division, i. e., r = m % n.
2. Euclid’s algorithm to determine the GCD of two numbers m and n is
given below and its action is illustrated for m= 50 and n = 35.
3. In each iteration of this loop, we determine the remainder (r = m % n) and
assign current values of variables n and r to variables m and n,
respectively.
4. Execution is continued as long as the value of divisor n is greater than
zero.
5. When the value of n becomes zero, the value of variable m is the GCD of
the given numbers

Program :

#include <iostream.h>
#include <conio.h>
void main() {
int m, n; /* given numbers */
clrscr();
cout<<"Enter-two integer numbers: ";
cin>>m>>n;
while (n > 0) {
int r = m % n;

43
m = n;
n = r;
}
cout<<"GCD =”<<m;
getch();
}

Output :

Result :

GCD of two numbers was computed using modular arithmetic operations


and the output is verified.

44
Ex.No : 10
Date :
BIN PACKING

Aim :

To determine the minimum number of bin needed to accommodate all n


objects.

Algorithm :

1. Order the given objects in a non-decreasing order so that


we have s1 ≥ · · · ≥ sn.
Initialize a counter N = 0.

2. Let the bins be B1, · · · , Bn. Put the next (first) object in the first
“possible” bin , scanning the bins in the order B1, · · · , Bn. If a new bin is
used, increment N.

3. Return N.

Program :

#include <iostream.h>

void binpack(int *a, int size, int n)

int bincount =1;

int s = size;

int i;

for (i=0;i<n;i++)

if (s - *(a+i) > 0)

s -= *(a+i);

45
continue;

else

bincount++;

s=size;

i--;

cout<<"Number of bins required:"<<bincount;

void main()

int n,size;

int a[20];

cout<<"Bin packing Algorithm\n";

cout<<"Enter the number of items in set :";

cin>>n;

cout<<"Enter "<<n<<"items:";

for (i=0;i<n;i++)

cin>>a[i];

cout<<"Enter the bin size:";

cin>>size;

binpack(a,size,n);

46
Output:

BIN - PACKING Algorithm


Enter the number of items in Set: 5
Enter 5 items:12 23 34 45 56
Enter the bin size: 70
Number of bins required: 3

Result :

The minimum number of bin needed to accommodate all n objects is


obtained and the output is verified.

47

You might also like