Monday, January 7, 2013

Design Analysis Algorithm Lab programming

 

 

 

/*1. MERGE SORT USING DIVIDE AND CONQUER METHOD */

#include<iostream.h>

#include<conio.h>

class mergesort

{

int a[20];

void merge(int,int,int);

public:

void create(int);

void merge_sort(int,int);

void print(int);

};

void mergesort :: create(int n)

{

int i;

cout<<"\n Enter the array elements\n";

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

cin>>a[i];

}

void mergesort :: merge_sort(int p,int r)

{

int q;

if(p<r)

{

q=((p+r)/2);

merge_sort(p,q);

merge_sort(q+1,r);

merge(p,q,r);

}

}

void mergesort :: merge(int x,int y,int z)

{

int n1=y-x+1,n2=z-y,i,j,k,l[20],r[20];

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

l[i]=a[x+i-1];

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

r[j]=a[y+j];

l[n1+1]=999;

r[n2+1]=999;

i=j=1;

for(k=x;k<=z;k++)

{

if(l[i]<=r[j])

{

a[k]=l[i];

i=i+1;

}

else

{

a[k]=r[j];

j=j+1;

}

}

}

void mergesort :: print(int n)

{

int i;

cout<<"\n After sorting the elements are \n";

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

cout<<a[i];

}

void main()

{

int l,n,r;

mergesort ob;

clrscr();

cout<<"\n\t\t\t merge sort";

cout<<"\n\t\t\t ~~~~~~~~~~~";

cout<<"\n Enter the size of the array:";

cin>>n;

ob.create(n);

l=0;

r=n-1;

ob.merge_sort(l,r);

ob.print(n);

getch();

}

OUTPUT:

MERGE SORT

~~~~~~~~~~~

Enter the size of the array: 5

Enter the array elements

77

88

99

45

22

After sorting the elements are

22

45

77

88

99

/*2. STRASSEN’S MATRIX MULTIPLICATION */

#include<iostream.h>

#include<conio.h>

#include<stdlib.h>

class strassen

{

int a[2][2],b[2][2],c[2][2];

public:

void product()

{

int q1,q2,q3,q4,q5,q6,q7;

q1=(a[1][1]+a[2][2])*(b[1][1]+b[2][2]);

q2=(a[2][1]+a[2][2])*b[1][1];

q3=a[1][1]*(b[1][2]-b[2][2]);

q4=a[2][2]*(-b[1][1]+b[2][1]);

q5=(a[1][1]+a[1][2])*b[2][2];

q6=(-a[1][1]+a[2][1])*(b[1][1]+b[1][2]);

q7=(a[1][2]-a[2][2])*(b[2][1]+b[2][2]);

c[1][1]=q1+q4-q5+q7;

c[1][2]=q3+q5;

c[2][1]=q2+q4;

c[2][2]=q1+q3-q2+q6;

}

void read();

void display();

};

void strassen :: read()

{

cout<<"\n Enter the matrix A elements\n";

for(int i=1;i<=2;i++)

for(int j=1;j<=2;j++)

cin>>a[i][j];

cout<<"\n Enter the matrix B elements \n";

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

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

cin>>b[i][j];

}

void strassen::display()

{

cout<<"\n The product of the matrix is \n";

for(int i=1;i<=2;i++)

for(int j=1;j<=2;j++)

{

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

cout<<endl;

}

}

void main()

{

strassen ob;

clrscr();

cout<<"\n\t\t\t MATRIX MULTIPLICATION";

cout<<"\n\t\t\t ~~~~~~~~~~~~~~~~~~~~~~";

ob.read();

ob.product();

ob.display();

getch();

}

OUTPUT:

MATRIX MULTIPLICATION

~~~~~~~~~~~~~~~~~~~~~~

Enter the matrix A elements

1 2

3 4

Enter the matrix B elements

5 6

7 8

The product of the matrix is

19 22

43 50

/ *3. KNAPSACK USING GREEDY METHOD * /

#include<iostream.h>

#include<conio.h>

#include<iomanip.h>

class knapsack

{

float w[10],p[10],profit,r[10],t;

int m,n,i,j,k;

public:

knapsack();

void sort();

void calc();

};

knapsack::knapsack()

{

clrscr();

cout<<"\n\t\t\tKNAPSACK PROBLEM";

cout<<"\n\t\t\t----------------";

cout<<"\n\nEnter the capacity of the bag";

cin>>m;

cout<<"\nEnter the no. of items";

cin>>n;

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

{

cout<<"\nEnter the weight and profit of items"<<i<<":";

cin>>w[i]>>p[i];

r[i]=(float)p[i]/w[i];

}

profit=0.0;

}

void knapsack::sort()

{

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

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

{

if(r[j]<r[j+1])

{

t=r[j];

r[j]=r[j+1];

r[j+1]=t;

t=p[j];

p[j]=p[j+1];

p[j+1]=t;

t=w[j];

w[j]=w[j+1];

w[j+1]=t;

}

}

}

void knapsack::calc()

{

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

{

if(w[i]<=m)

{

m=m-w[i];

profit=profit+p[i];

}

else

{

profit=profit+(p[i]/w[i])*m;

break;

}

}

cout<<"Profit is : "<<profit;

}

void main()

{

knapsack k;

k.sort();

k.calc();

getch();

}

OUTPUT:

KNAPSACK PROBLEM

*********************

Enter the capacity of the bag: 20

Enter the no. of items:3

Enter the weight and profit of items1:18 25

Enter the weight and profit of items2:15 24

Enter the weight and profit of items3:1015

Profit is: 31.5

/ * 4. KRUSKAL’S MINIMUM SPANNING TREE * /

#include<iostream.h>

#include<conio.h>

#include<stdlib.h>

class kruskal

{

int p1[20],rank[20];

struct graph

{

int c,i,j;

struct graph *link;

};

typedef struct graph node;

node *head,*p,*q;

int v,u,a[20][20],n,w[20][20],t,cnt,cost;

public:

void makeset(int);

int findset(int);

void uinion(int,int);

void link(int,int);

void sort();

kruskal();

}

kruskal::kruskal()

{

clrscr();

t=1;

cnt=1;

cost=0;

cout<<"\n\t\t\tKRUSKAL'S MINIMUM SPANNING TREE";

cout<<"\n\t\t\t*******************************";

cout<<"\n\nEnter the number of vertices:";

cin>>n;

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

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

a[i][j]=-1;

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

makeset(i);

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

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

{

if((a[i][j]==-1)&&(i!=j))

{

cout<<"\n\nEnter the cost of the edge"<<i<<"and"<<j<<":";

cin>>a[i][j];

a[j][i]=a[i][j];

if(t==1)

{

p=(node*)malloc(sizeof(node));

p->i=i;

p->j=j;

p->c=a[i][j];

p->link=NULL;

head=p;

t++;

}

else

{

q=(node*)malloc(sizeof(node));

q->i=i;

q->j=j;

q->c=a[i][j];

q->link=NULL;

p->link=q;

p=q;

cnt=cnt+1;

}

}

}

sort();

p=head;

t=1;

cout<<"\nThe minimum spanning tree is\n";

while(p!=NULL)

{

if(findset(p->i)!=findset(p->j))

{

uinion(p->i,p->j);

cost=cost+p->c;

cout<<p->i<<"-->"<<p->j<<endl;

}

p=p->link;

}

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

}

void kruskal::sort()

{

for(int i=1;i<=cnt;i++)

{

p=head;

for(int j=1;j<=cnt-i;j++)

{

if(p->c>p->link->c&&p->link!=NULL)

{

int t=p->c;

p->c=p->link->c;

p->link->c=t;

t=p->i;

p->i=p->link->i;

p->link->i=t;

t=p->j;

p->j=p->link->j;

p->link->j=t;

p=p->link;

}

else p=p->link;

}

}

}

void kruskal::makeset(int x)

{

p1[x]=x;

rank[x]=0;

}

void kruskal::uinion(int x,int y) //adding to the list

{

link(findset(x),findset(y));

}

void kruskal::link(int x,int y) //checking for cyclic

{

if(rank[x]>rank[y])

p1[y]=x;

else p1[x]=y;

if(rank[x]==rank[y])

rank[y]=rank[y]+1;

}

int kruskal::findset(int x) //path compression

{

if(x!=p1[x])

p1[x]=findset(p1[x]);

return p1[x];

}

void main() //main program

{

kruskal k;

getch();

}

OUTPUT:

KRUSKAL'S MINIMUM SPANNING TREE

***************************************

Enter the number of vertices:4

Enter the cost of the edge1and2:5

Enter the cost of the edge1and3:10

Enter the cost of the edge1and4:999

Enter the cost of the edge2and3:999

Enter the cost of the edge2and4:15

Enter the cost of the edge3and4:20

The minimum spanning tree is

1-->2

1-->3

2-->4

The cost is:30

/ *5. BREADTH FIRST SEARCH */

#include<iostream.h>

#include<conio.h>

int a[10][10],visited[10],n;

void search_from1(int);

void main()

{

int i,j;

clrscr();

cout<<"\n Enter the number of nodes:";

cin>>n;

cout<<"\n Enter the adjancency matrix:\n";

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

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

if(i!=j)

{

cout<<"\nEnter the value of "<<i<<j<<”element”;

cin>>a[i][j];

}

cout<<"\n Nodes are visited in the order";

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

if(visited[i]==0)

search_from1(i);

getch();

}

void search_from1(int z)

{

int i,j;

cout<<"-->"<<z;

visited[z]=1;

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

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

{

if(visited[i]==0)

if(a[z][j]!=0)

search_from1(i);

break;

}

getch();

}

OUTPUT:

BREADTH FIRST SEARCH

Enter the number of nodes:4

Enter the adjancency matrix:

Enter the value of 12 element 1

Enter the value of 13 element 0

Enter the value of 14 element 0

Enter the value of 21 element 1

Enter the value of 23 element 0

Enter the value of 24 element 1

Enter the value of 31 element 1

Enter the value of 32 element 0

Enter the value of 34 element 0

Enter the value of 41 element 0

Enter the value of 42 element 1

Enter the value of 43 element 1

Nodes are visited in the order

-->1-->2-->3-->4

*6. DEPTH FIRST SEARCH * /

#include<iostream.h>

#include<conio.h>

int a[10][10],visited[10],n;

void search_from(int);

void main()

{

int i,j;

clrscr();

cout<<"\n Enter the number of nodes:";

cin>>n;

cout<<"\n Enter the adjancency matrix:\n";

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

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

if(i!=j)

{

cout<<"\nEnter the value of "<<i<<j<<” element”;

cin>>a[i][j];

}

cout<<"\n Nodes are visited in the order";

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

if(visited[i]==0)

search_from(i);

getch();

}

void search_from(int k)

{

int i,j;

cout<<"-->"<<k;

visited[k]=1;

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

if(visited[i]==0)

if(a[k][i]!=0)

search_from(i);

getch();

}

OUTPUT:

DEPTH FIRST SEARCH

Enter the number of nodes:5

Enter the adjancency matrix:

Enter the value of 12 element 0

Enter the value of 13 element 1

Enter the value of 14 element 0

Enter the value of 15 element 0

Enter the value of 21 element 0

Enter the value of 23 element 0

Enter the value of 24 element 0

Enter the value of 25 element 1

Enter the value of 31 element 0

Enter the value of 32 element 1

Enter the value of 34 element 1

Enter the value of 35 element 0

Enter the value of 41 element 0

Enter the value of 42 element 0

Enter the value of 43 element 0

Enter the value of 45 element 0

Enter the value of 51 element 0

Enter the value of 52 element 0

Enter the value of 53 element 0

Enter the value of 54 element 0

Nodes are visited in the order

-->1-->3-->2-->5-->4

/ *7. BINARY TREE TRAVERSAL */

#include<iostream.h>

#include<conio.h>

#include<malloc.h>

struct bnode

{

int data;

struct bnode *left,*right;

}*bt;

void create()

{

struct bnode *temp,*p,*pre;

int flag,key,d;

bt=NULL;

cout<<"\n \t Read the value until -1 to exit:\n\t ";

cin>>d;

while(d!=-1)

{

temp=(struct bnode *)(malloc(sizeof(struct bnode)));

temp->data=d;

temp->left=NULL;

temp->right=NULL;

if(bt==NULL)

bt=temp;

else

{

p=bt;

pre=bt;

while(p!=NULL)

{

key=p->data;

if(d<key)

{

flag=0;

pre=p;

p=p->left;

}

else if(d>key)

{

flag=1;

pre=p;

p=p->right;

}

}

if(flag==0)

pre->left=temp;

else

pre->right=temp;

}

cin>>d;

}

}

void preord(struct bnode *p)

{

if(p==NULL)

return;

cout<<"\t"<<p->data;

if(p->left!=NULL)

preord(p->left);

if(p->right)

preord(p->right);

}

void postord(struct bnode *p)

{

if(p==NULL)

return;

if(p->left)

postord(p->left);

if(p->right)

postord(p->right);

cout<<"\t"<<p->data;

}

void inord(struct bnode *p)

{

if(p==NULL)

return;

if(p->left)

inord(p->left);

cout<<"\t"<<p->data;

if(p->right)

inord(p->right);

}

void main()

{

clrscr();

create();

cout<<"\n\tINORDER TRAVERSAL\n\t";

inord(bt);

cout<<"\n\tPREORDER TRAVERSAL\n\t";

preord(bt);

cout<<"\n\tPOSTORDER TRAVERSAL\n\t";

postord(bt);

getch();

}

OUTPUT:

BINARY TREE TRAVERSAL

~~~~~~~~~~~~~~~~~~~~~~~~~~

Read the value until -1 to exit:

45 67 89 34 12 78 110 -1

INORDER TRAVERSAL

12 34 45 67 78 89 110

PREORDER TRAVERSAL

45 34 12 67 89 78 110

POSTORDER TRAVERSAL

12 34 78 110 89 67 45

/ *8. SHORTEST PATH * /

#include<iostream.h>

#include<conio.h>

void shortestpath(int ,int);

int graph,costs=32760,cost1,num,sor,dest,edge;

int from[20],to[20],cost[20],path[10];

void shortestpath(int graph,int z)

{

int temp,k=0,i=-1,p[10];

for(temp=z;temp<edge;temp++)

{

if(graph==from[temp])

{

p[k]=graph;

i++;

if(to[temp]==dest)

{

cost1=cost1+cost[temp];

if(cost1<costs)

{

costs=cost1;

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

path[z]=p[z];

num=temp;

break;

}

}

else

{

graph=to[temp];

cost1=cost1+cost[temp];

k++;

}

}

}

}

void main()

{

int i,z,cost2;

clrscr();

cout<<"\n Enter the number of edge:";

cin>>edge;

cout<<"\nEnter the source:";

cin>>sor;

cout<<"\nEnter the destination";

cin>>dest;

cout<<"\nDestination"<<"\t\t"<<"Cost";

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

{

cout<<"From";

cin>>from[i];

cout<<"\nTo";

cin>>to[i];

cout<<"\nCost";

cin>>cost[i];

}

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

{

if(sor==from[i])

{

graph=to[i];

cost2=cost[i];

for(z=i;z<edge;z++)

{

if(graph==from[z])

{

cost1=cost2;

shortestpath(graph,z);

}

else if(graph==dest)

{

cost1=cost2;

if(cost1<costs)

{

costs=cost1;

num=0;

break;

}

}

}

}

}

cout<<"Cost:"<<costs;

cout<<"Path:"<<sor;

for(z=0;z<num;z++)

cout<<"->"<<path[z];

cout<<"->"<<dest;

getch();

}

OUTPUT:

SHORTEST PATH

Enter the number of edge: 3

Enter the source: 1

Enter the destination: 3

Source Destination Cost

From1

To2

Cost7

From1

To5

Cost7

From1

To3

Cost78

Cost: 78, Path: 1->3

/* 9.QUEENS PROBLEM USING BACKTRACKING */

#include<iostream.h>

#include<conio.h>

#include<math.h>

#include<process.h>

#include<graphics.h>

class queen

{

int n,x[100];

public:

queen();

void nqueen(int,int);

int place(int,int);

};

queen::queen()

{

int k=1;

textcolor(GREEN);

cprintf("Enter the number of queens:");

cin>>n;

nqueen( k, n);

}

void queen::nqueen(int k,int n)

{

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

{

if(place(k,i))

{

x[k]=i;

clrscr();

if(k==n)

{

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

{textcolor(x[j]);

gotoxy(1,j);

cprintf("queen %d : %d",j,x[j]);

}

getch();

break;

}

else

nqueen(k+1,n);

}

}

return;

}

int queen::place(int k,int i)

{

int j;

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

{

if((x[j]==i)||(abs(x[j]-i)==abs(j-k)))

return 0;

}

return 1;

}

void main()

{

clrscr();

queen q;

}

OUTPUT:

/* QUEENS PROBLEM USING BACKTRACKING */

Enter the number of queens: 8

queen 1: 1

queen 2: 5

queen 3 : 8

queen 4 : 6

queen 5 : 3

queen 6 : 7

queen 7 : 2

queen 8 : 4

queen 1: 8

queen 2: 4

queen 3: 1

queen 4: 3

queen 5: 6

queen 6: 2

queen 7: 7

queen 8: 5

/*10. KNAPSACK USING BACKTRACKING */

#include<iostream.h>

#include<conio.h>

class knapsack

{

int m,n,w[10],p[10],fw,fp,x[10],y[10],b,c;

float r[10];

int bound(int,int,int);

public:

knapsack();

void bknap(int,int,int);

void display();

};

knapsack::knapsack()

{

fp=-1;

cout<<"\n Enter the no of items:";

cin>>n;

cout<<"\n Enter the capacity of the bag:";

cin>>m;

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

{

a:cout<<"\n Enter the weight and profit for the item "<<i<<":";

cin>>w[i]>>p[i];

r[i]=(float)p[i]/w[i];

if(i!=1)

if(r[i-1]<r[i])

{

cout<<"\n This entry is not valid \n";

goto a;

}

}

}

void knapsack::display()

{

cout<<"\n\n The selected items are \n\n";

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

cout<<" "<<i;

cout<<endl;

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

cout<<" "<<"**";

cout<<endl;

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

cout<<" "<<x[i];

cout<<"\n\n Final weight="<<fw;

cout<<"\n\n Final profit="<<fp;

}

void knapsack::bknap(int k,int cp,int cw)

{

if(cw+w[k]<=m)

{

y[k]=1;

if(k<n)bknap(k+1,cp+p[k],cw+w[k]);

if(((cp+p[k])>fp)&&(k==n))

{

fp=cp+p[k];

fw=cw+w[k];

for(int j=1;j<=k;j++)

x[j]=y[j];

}

}

if(bound(cp,cw,k)>=fp)

{

y[k]=0;

if(k<n)bknap(k+1,cp,cw);

if((cp>fp)&&(k==n))

{

fp=cp;

fw=cw;

for(int j=1;j<=k;j++)

x[j]=y[j];

}

}

}

int knapsack::bound(int cp,int cw,int k)

{

b=cp;

c=cw;

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

{

c=c+w[i];

if(c<m)

b=b+p[i];

else return(b+(1-(c-m)/w[i])*p[i]);

}

return b;

}

void main()

{

clrscr();

cout<<"\n\t\t\t KNAPSACK USING BACKTRACKING";

cout<<"\n\t\t\t ***************************";

knapsack ob;

int k=1,cp=0,cw=0;

ob.bknap(k,cp,cw);

ob.display();

getch();

}

OUTPUT:

KNAPSACK USING BACKTRACKING

**********************************

Enter the no of items: 8

Enter the capacity of the bag: 110

Enter the weight and profit for the item 1:1 11

Enter the weight and profit for the item 2:11 21

Enter the weight and profit for the item 3:21 31

Enter the weight and profit for the item 4:23 33

Enter the weight and profit for the item 5:33 43

Enter the weight and profit for the item 6:43 53

Enter the weight and profit for the item 7:45 55

Enter the weight and profit for the item 8:55 65

The selected items are

1 2 3 4 5 6 7 8

** ** ** ** ** ** ** **

1 1 1 0 1 1 0 0

Final weight=109

Final profit=159

 

No comments:

Post a Comment