DAA Lab Manual (R16)
DAA Lab Manual (R16)
DAA Lab Manual (R16)
LAB MANUAL
Subject Code: CS505PC
Regulations : R16-JNTUH
Class : III Year B.Tech. CSE and IT I Semester
Prepared By
0
VISION AND MISSION OF THE INSTITUTION
Vision
To achieve the autonomous and university status and spread universal education by
inculcating discipline, character and knowledge into the young minds and mould them
into enlightened citizens.
Mission
BIET’s mission is to impart high quality education to students in the field of
Engineering and Technology and to conduct advanced research programs by fostering
close partnership with R&D institutions and Industry.
Serving the high quality educational needs of local and rural students within the core
areas of Computer Science and Engineering and Information Technology through a
rigorous curriculum of theory, research and collaboration with other disciplines that is
distinguished by its impact on academia, industry and society.
Mission
To work closely with industry and research organizations to provide high quality
computer education in both the theoretical and applications of Computer Science and
Engineering.
The department encourages original thinking, fosters research and development,
evolve innovative applications of technology.
1
COMPUTER SCIENCE AND ENGINEERING
&
INFORMATION TECHNOLOGY
Program Educational Objectives (PEOs):
Program Educational Objective 1: (PEO1)
The graduates of Computer Science and Engineering will have successful career in technology or
managerial functions.
Program Educational Objective 2: (PEO2)
The graduates of the program will have solid technical and professional foundation to continue higher
studies.
Program Educational Objective 3: (PEO3)
The graduates of the program will have skills to develop products, offer services and create new
knowledge.
Program Educational Objective 4: (PEO4)
The graduates of the program will have fundamental awareness of Industry processes, tools and
technologies.
2
PO10 Communication: Communicate effectively on complex engineering activities with the engineering
community and with society at large, such as, being able to comprehend and write effective reports
and design documentation, make effective presentations, and give and receive clear instructions.
PO11 Project management and finance: Demonstrate knowledge and understanding of the engineering
and management principles and apply these to one's own work, as a member and leader in a team,
to manage projects and in multidisciplinary environments.
PO12 Life-long learning: Recognize the need for, and have the preparation and ability to engage in
independent and life-long learning in the broadest context of technological change.
3
S. No. List of Experiments Page No.
System Requirements 6
JNTUH Syllabus
5 Write a java program to implement the bfs algorithm for a graph. 18-21
4
ATTAINMENT OF PROGRAM OUTCOMES & PROGRAM SPECIFIC
OUTCOMES
S. NAME OF EXPERIMENT Program Program Specific
NO Outcomes(POs) Outcomes(PSOs)
Attained Attained
1 Write a java program to implement Bubble sort PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for sorting a list of integers in ascending
order*
2 Write a java program to implement Quick sort PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for sorting a list of integers in ascending
order
3 Write a java program to implement Merge sort PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for sorting a list of integers in ascending
order.
4 Write a java program to implement the dfs PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for a graph.
5 Write a java program to implement the bfs PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for a graph.
6 Write a java programs to implement backtracking PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for the N-queens problem.
7 Write a java program to implement the PO1, PO2,PO4,PO5 PSO1,PSO2
backtracking algorithm for the sum of subsets
problem.
8 Write a java program to implement the PO1, PO2,PO4,PO5 PSO1,PSO2
backtracking algorithm for the Hamiltonian
Circuits problem.
9 Write a java program to implement greedy PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for job sequencing with deadlines.
10 Write a java program to implement Dijkstra’s PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for the Single source shortest path
problem.
11 Write a java program that implements Prim’s PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm to generate minimum cost spanning
tree.
12 Write a java program that implements Kruskal’s PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm to generate minimum cost spanning tree
13 Write a java program to implement Floyd’s PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for the all pairs shortest path problem.
14 Write a java program to implement Dynamic PO1, PO2,PO4,PO5 PSO1,PSO2
Programming algorithm for the 0/1 Knapsack
problem.
15 Write a java program to implement Dynamic PO1, PO2,PO4,PO5 PSO1,PSO2
Programming algorithm for the Optimal Binary
Search Tree Problem.
16 Write a java program to implement Greedy PO1, PO2,PO4,PO5 PSO1,PSO2
algorithm for the 0/1 Knapsack problem.*
*Experiments out of syllabus.
5
System Requirements
1. Intel based desktop PC with minimum of 2.6GHz or faster processor with at least 1GB RAM
and 40 GB free disk space and LAN connected.
2. Operating System: Ubuntu.
3. Software: JAVA Compiler
To write programs in java to solve problems using divide and conquer strategy.
To write programs in java to solve problems using backtracking strategy.
To write programs in java to solve problems using greedy and dynamic programming
techniques.
Course Outcomes:
Ability to write programs in java to solve problems using algorithm design techniques such as Divide
and Conquer, Greedy, Dynamic programming, and Backtracking.
CO-PO Mapping:
Program Outcomes (PO's)
Course
outcomes PO1 PO2 PO3 PO4 PO5 PO6 PO7 PO8 PO9 PO10 PO11 PO12 PSO1 PS02 PS03
CO1 3 3 2 2 - - - - - - - 2 2 -
Average 3 3 2 2 - - - - - - - 2 2 -
6
EXPERIMENT 1 - BUBBLE SORT
AIM:
Write a java program to implement Bubble sort algorithm for sorting a list of integers
in ascending order
DESCRIPTION:
Bubble sort, is a simple sorting algorithm that repeatedly steps through the list to be sorted, compares each pair
of adjacent items and swaps them if they are in the wrong order. The pass through the list is repeated until no
swaps are needed, which indicates that the list is sorted. Although the algorithm is simple, it is too slow and
impractical for most problems even when compared to insertion sort. Bubble sort can be practical if the input is
in mostly sorted order with some out-of-order elements nearly in position.
Bubble sort has a worst-case and average complexity of О(n2), where n is the number of items being sorted.
PROGRAM:
import java.util.Scanner;
class BubbleSort {
public static void main(String []args) {
int n, c, d, swap;
Scanner in = new Scanner(System.in);
7
for (c = 0; c < n; c++)
System.out.println(array[c]);
}
}
OUTPUT:
Input number of integers to sort
5
Enter integers
96732
Sorted list of numbers
23679
8
EXPERIMENT 2 - QUICK SORT
AIM:
Write a java program to implement Quick sort algorithm for sorting a list of integers in ascending order
DESCRIPTION:
Quick sort is a divide and conquer algorithm. Quicksort first divides a large array into two smaller sub-arrays:
the low elements and the high elements. Quicksort can then recursively sort the sub-arrays. The steps are:
1. Pick an element, called a pivot, from the array.
2. Partitioning: reorder the array so that all elements with values less than the pivot come before the pivot,
while all elements with values greater than the pivot come after it (equal values can go either way).
After this partitioning, the pivot is in its final position. This is called the partition operation.
3. Recursively apply the above steps to the sub-array of elements with smaller values and separately to the
sub-array of elements with greater values.
PROGRAM:
import java.util.Random;
import java.util.Scanner;
public class quicksort {
static int max=2000;
int partition (int[] a, int low,int high)
{
int p,i,j,temp;
p=a[low];
i=low+1;
j=high;
while(low<high)
{
while(a[i]<=p&&i<high)
i++;
while(a[j]>p)
j--;
if(i<j)
{
temp=a[i];
a[i]=a[j];
a[j]=temp;
}
else
{
temp=a[low];
a[low]=a[j];
a[j]=temp;
return j;
}
9
}
return j;
}
void sort(int[] a,int low,int high)
{
if(low<high)
{
int s=partition(a,low,high);
sort(a,low,s-1);
sort(a,s+1,high);
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] a;
int i;
System.out.println("Enter the array size");
Scanner sc =new Scanner(System.in);
int n=sc.nextInt();
a= new int[max];
Random generator=new Random();
for( i=0;i<n;i++)
a[i]=generator.nextInt(20);
System.out.println("Array before sorting");
for( i=0;i<n;i++)
System.out.println(a[i]+" ");
long startTime=System.nanoTime();
quicksort m=new quicksort();
m.sort(a,0,n-1);
long stopTime=System.nanoTime();
long elapseTime=(stopTime-startTime);
System.out.println("Time taken to sort array is:"+elapseTime+"nano
seconds");
System.out.println("Sorted array is");
for(i=0;i<n;i++)
System.out.println(a[i]);
}
}
OUTPUT:
Enter the array size
10
Array before sorting
17
10
17
12
2
10
3
18
15
15
17
Time taken to sort array is:16980 nano seconds
Sorted array is
23
10
12
15
15
17
17
17
18
11
EXPERIMENT 3 - MERGE SORT
AIM:
Write a java program to implement Merge sort algorithm for sorting a list of integers
in ascending order
DESCRIPTION:
Merge sort is a divide and conquer algorithm . Conceptually, a merge sort works as follows:
1. Divide the unsorted list into n sublists, each containing 1 element (a list of 1 element is considered
sorted).
2. Repeatedly merge sublists to produce new sorted sublists until there is only 1 sublist remaining. This
will be the sorted list.
PROGRAM:
import java.util.Random;
import java.util.Scanner;
public class mergesort {
static int max=10000;
void merge( int[] array,int low, int mid,int high)
{
int i=low;
int j=mid+1;
int k=low;
int[]resarray;
resarray=new int[max];
while(i<=mid&&j<=high)
{
if(array[i]<array[j])
{
resarray[k]=array[i];
i++;
k++;
}
else
{
resarray[k]=array[j];
j++;
k++;
}
}
while(i<=mid)
resarray[k++]=array[i++];
while(j<=high)
resarray[k++]=array[j++];
for(int m=low;m<=high;m++)
12
array[m]=resarray[m];
}
void sort( int[] array,int low,int high)
{
if(low<high)
{
int mid=(low+high)/2;
sort(array,low,mid);
sort(array,mid+1,high);
merge(array,low,mid,high);
}
}
public static void main(String[] args) {
int[] array;
int i;
System.out.println("Enter the array size");
Scanner sc =new Scanner(System.in);
int n=sc.nextInt();
array= new int[max];
Random generator=new Random();
for( i=0;i<n;i++)
array[i]=generator.nextInt(20);
System.out.println("Array before sorting");
for( i=0;i<n;i++)
System.out.println(array[i]+" ");
long startTime=System.nanoTime();
mergesort m=new mergesort();
m.sort(array,0,n-1);
long stopTime=System.nanoTime();
long elapseTime=(stopTime-startTime);
System.out.println("Time taken to sort array is:"+elapseTime+"nano
seconds");
System.out.println("Sorted array is");
for(i=0;i<n;i++)
System.out.println(array[i]);
}
}
OUTPUT:
Enter the array size
10
Array before sorting
13
9
13
13
16
13
3
0
6
4
5
Time taken to sort array is:171277nano seconds
Sorted array is
0
3
4
5
6
9
13
13
13
16
14
EXPERIMENT 4 - DFS
AIM:
DESCRIPTION:
Depth-first search (DFS) is an algorithm for traversing or searching tree or graph data structures. The
algorithm starts at the root node (selecting some arbitrary node as the root node in the case of a graph) and
explores as far as possible along each branch before backtracking.
PROGRAM:
import java.util.InputMismatchException;
import java.util.Scanner;
import java.util.Stack;
public DFS()
{
stack = new Stack<Integer>();
}
while (!stack.isEmpty())
{
element = stack.peek();
i = element;
while (i <= number_of_nodes)
{
if (adjacency_matrix[element][i] == 1 && visited[i] == 0)
{
stack.push(i);
visited[i] = 1;
15
element = i;
i = 1;
System.out.print(element + "\t");
continue;
}
i++;
}
stack.pop();
}
}
OUTPUT:
Enter the number of nodes in the graph
4
Enter the adjacency matrix
16
0101
0010
0101
0001
Enter the source for the graph
1
The DFS Traversal for the graph is given by
1 2 3 4
17
EXPERIMENT 5 - BFS
AIM:
DESCRIPTION:
Breadth-first search (BFS) is an algorithm for traversing or searching tree or graph data structures. It starts at
the tree root (or some arbitrary node of a graph, sometimes referred to as a 'search key, and explores all of the
neighbor nodes at the present depth prior to moving on to the nodes at the next depth level.
PROGRAM:
Write a java program to implement the BFS algorithm for a graph.
import java.util.InputMismatchException;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;
public class BFS
{
private Queue<Integer> queue;
public BFS()
{
queue = new LinkedList<Integer>();
}
public void bfs(int adjacency_matrix[][], int source)
{
int number_of_nodes = adjacency_matrix[source].length - 1;
while (!queue.isEmpty())
{
element = queue.remove();
i = element;
System.out.print(i + "\t");
while (i <= number_of_nodes)
{
if (adjacency_matrix[element][i] == 1 && visited[i] == 0)
{
queue.add(i);
visited[i] = 1;
}
i++;
18
}
}
}
public static void main(String... arg)
{
int number_no_nodes, source;
Scanner scanner = null;
try
{
System.out.println("Enter the number of nodes in the graph");
scanner = new Scanner(System.in);
number_no_nodes = scanner.nextInt();
int adjacency_matrix[][] = new int[number_no_nodes + 1][number_no_nodes + 1];
System.out.println("Enter the adjacency matrix");
for (int i = 1; i <= number_no_nodes; i++)
for (int j = 1; j <= number_no_nodes; j++)
adjacency_matrix[i][j] = scanner.nextInt();
System.out.println("Enter the source for the graph");
source = scanner.nextInt();
System.out.println("The BFS traversal of the graph is ");
BFS bfs = new BFS();
bfs.bfs(adjacency_matrix, source);
OUTPUT:
Enter the number of nodes in the graph
4
Enter the adjacency matrix
0101
0010
0101
0001
Enter the source for the graph
1
The BFS traversal of the graph is
1 2 4 3
19
EXPERIMENT 6 - N-QUEENS PROBLEM
AIM:
Write a java programs to implement backtracking algorithm for the N-queens problem.
DESCRIPTION:
The N Queen is the problem of placing N chess queens on an N×N chessboard so that no two queens attack
each other. For example, following is a solution for 4 Queen problem.
PROGRAM:
import java.io.*;
class operation
{
int x[]=new int[20];
int count=0;
public boolean place(int row,int column)
{
int i;
for(i=1;i<=row-1;i++)
{ //checking for column and diagonal conflicts
if(x[i] == column)
return false;
else
if(Math.abs(x[i] – column) == Math.abs(i – row))
return false;
}
return true;
}
public void Queen(int row,int n)
{
int column;
for(column=1;column<=n;column++)
{
if(place(row,column))
{
x[row] = column;
if(row==n)
print_board(n);//printing the board configuration
else //try next queen with next position
Queen(row+1,n);
}
}
}
20
public void print_board(int n)
{
int i;
System.out.println(“\n\nSolution :”+(++count));
for(i=1;i<=n;i++)
{
System.out.print(” “+i);
}
for(i=1;i<=n;i++)
{
System.out.print(“\n\n”+i);
for(int j=1;j<=n;j++)// for nXn board
{
if(x[i]==j)
System.out.print(” Q”);
else
System.out.print(” -“);
}}
}}
class BacktrackDemo
{
public static void main (String args[] )throws IOException
{
DataInputStream in=new DataInputStream(System.in);
System.out.println(“Enter no Of Queens”);
int n=Integer.parseInt(in.readLine());
operation op=new operation();
op.Queen(1,n);
}
}
OUTPUT:
Enter no Of Queens
4
Solution :1
1234
1–Q––
2–––Q
3Q–––
4––Q–
Solution :2
1234
1––Q–
2Q–––
3–––Q
4–Q––
21
EXPERIMENT 7 - SUM OF SUBSETS PROBLEM
AIM:
Write a java program to implement the backtracking algorithm for the sum of subsets problem.
DESCRIPTION:
The subset sum problem is an important problem in complexity theory and cryptography. The problem is this:
given a set (or multiset) of integers, is there a non-empty subset whose sum is zero? For example, given the set
{−7, −3, −2, 5, 8}, the answer is yes because the subset {−3, −2, 5} sums to zero. The problem is NP-complete,
meaning roughly that while it is easy to confirm whether a proposed solution is valid, it may inherently be
prohibitively difficult to determine in the first place whether any solution exists.
PROGRAM:
// A recursive solution for subset sum problem
class GFG {
// Returns true if there is a subset of set[] with sum equal to given sum
static boolean isSubsetSum(int set[], int n, int sum)
{
if (sum == 0)
return true;
if (n == 0 && sum != 0)
return false;
// If last element is greater than sum, then ignore it
if (set[n-1] > sum)
return isSubsetSum(set, n-1, sum);
/* else, check if sum can be obtained by any of the following
(a) including the last element
(b) excluding the last element */
return isSubsetSum(set, n-1, sum) || isSubsetSum(set, n-1, sum-set[n-1]);
}
public static void main (String args[])
{
int set[] = {3, 34, 4, 12, 5, 2};
int sum = 9;
int n = set.length;
if (isSubsetSum(set, n, sum) == true)
System.out.println("Found a subset" + " with given sum");
else
System.out.println("No subset with"+ " given sum");
}
}
OUTPUT:
Found a subset with given sum
22
EXPERIMENT 8 - HAMILTONIAN CIRCUITS
AIM:
Write a java program to implement the backtracking algorithm for the Hamiltonian Circuits problem.
DESCRIPTION:
Hamiltonian cycle problem are problems of determining whether a Hamiltonian path (a path in an
undirected or directed graph that visits each vertex exactly once) or a Hamiltonian cycle exists in a
given graph (whether directed or undirected). Both problems are NP-complete.
PROGRAM:
import java.util.Scanner;
import java.util.Arrays;
Arrays.fill(path, -1);
graph = g;
try
{
path[0] = 0;
pathCount = 1;
solve(0);
System.out.println("No solution");
}
catch (Exception e)
{
System.out.println(e.getMessage());
display();
}
}
/** function to find paths recursively **/
public void solve(int vertex) throws Exception
23
{
/** solution **/
if (graph[vertex][0] == 1 && pathCount == V)
throw new Exception("Solution found");
/** all vertices selected but last vertex not linked to 0 **/
if (pathCount == V)
return;
24
System.out.println();
}
/** Main function **/
public static void main (String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.println("HamiltonianCycle Algorithm Test\n");
/** Make an object of HamiltonianCycle class **/
HamiltonianCycle hc = new HamiltonianCycle();
hc.findHamiltonianCycle(graph);
}
}
OUTPUT:
HamiltonianCycle Algorithm Test
Enter number of vertices
Enter matrix
01011000
10100100
01010010
10100001
10000101
01001010
00100101
00011010
Solution found
Path : 0 1 2 3 7 6 5 4 0
25
EXPERIMENT 9 - JOB SEQUENCING WITH DEADLINES
AIM:
Write a java program to implement greedy algorithm for job sequencing with deadlines.
DESCRIPTION:
Given an array of jobs where every job has a deadline and associated profit if the job is finished before the
deadline. It is also given that every job takes single unit of time, so the minimum possible deadline for any job
is 1.
PROGRAM:
import java.util.*;
class job
{
int p; //.............for profit of a job
int d; //.............for deadline of a job
int v; //.............for checking if that job has been selected
job()
{
p=0;
d=0;
v=0;
}
job(int x,int y,int z) // parameterised constructor
{
p=x;
d=y;
v=z;
}}
class js
{
static int n;
static int out(job jb[],int x)
{
for(int i=0;i<n;++i)
if(jb[i].p==x)
return i;
return 0;
}
public static void main(String args[])
{
Scanner scr=new Scanner(System.in);
System.out.println("Enter the number of jobs");
26
n=scr.nextInt();
int max=0; // this is to find the maximum deadline
job jb[]=new job[n];
/***********************Accepting job from user*************************/
for(int i=0;i<n;++i)
{
System.out.println("Enter profit and deadline(p d)");
int p=scr.nextInt();
int d=scr.nextInt();
if(max<d)
max=d; // assign maximum value of deadline to "max" variable
jb[i]=new job(p,d,0); //zero as third parameter to mark that initially it is unvisited
}
//accepted jobs from user
/***************Sorting in increasing order of deadlines*********************/
for(int i=0;i<=n-2;++i)
{
for(int j=i;j<=n-1;++j)
{
if(jb[i].d>jb[j].d)
{
job temp=jb[i];
jb[i]=jb[j];
jb[j]=temp;
}
}
}
// sorting process ends
/*************************Displaying the jobs to the user*********************/
System.out.println("The jobs are as follows ");
for(int i=0;i<n;++i)
System.out.println("Job "+i+" Profit = "+jb[i].p+" Deadline = "+jb[i].d);
// jobs displayed to the user
int count;
int hold[]=new int[max];
for(int i=0;i<max;++i)
hold[i]=0;
/***********************Process of job sequencing begins*************************/
for(int i=0;i<n;++i)
{
count=0;
for(int j=0;j<n;++j)
{
27
if(count<jb[j].d && jb[j].v==0 && count<max && jb[j].p>hold[count])
{
int ch=0;
if(hold[count]!=0)
{
ch=out(jb,hold[count]);
jb[ch].v=0;
}
hold[count]=jb[j].p;
jb[j].v=1;
++count;
} // end of if
} //end of inner for
}// end of outer for
/**********************job sequencing process ends****************************/
/************************calculating max profit********************************/
int profit=0;
for(int i=0;i<max;++i)
profit+=hold[i];
System.out.println("The maximum profit is "+profit);
}//end main method
}//end class
OUTPUT:
Enter the number of jobs
4
Enter profit and deadline(p d)
70 2
Enter profit and deadline(p d)
12 1
Enter profit and deadline(p d)
18 2
Enter profit and deadline(p d)
35 1
The jobs are as follows
Job 0 Profit = 12 Deadline = 1
Job 1 Profit = 35 Deadline = 1
Job 2 Profit = 18 Deadline = 2
Job 3 Profit = 70 Deadline = 2
28
EXPERIMENT 10 - SINGLE SOURCE SHORTEST PATH PROBLEM
AIM:
Write a java program to implement Dijkstra’s algorithm for the Single source shortest path problem.
DESCRIPTION:
Single-Source Shortest Paths – Dijkstra's Algorithm. Given a source vertex s from set of vertices V in a
weighted graph where all its edge weights w(u, v) are non-negative, find the shortest-path weights d(s, v) from
given source s for all vertices v present in the graph.
PROGRAM:
import java.util.HashSet;
import java.util.InputMismatchException;
import java.util.Iterator;
import java.util.Scanner;
import java.util.Set;
29
unsettled.add(source);
distances[source] = 0;
while (!unsettled.isEmpty())
{
evaluationNode = getNodeWithMinimumDistanceFromUnsettled();
unsettled.remove(evaluationNode);
settled.add(evaluationNode);
evaluateNeighbours(evaluationNode);
}
}
30
{
edgeDistance = adjacencyMatrix[evaluationNode][destinationNode];
newDistance = distances[evaluationNode] + edgeDistance;
if (newDistance < distances[destinationNode])
{
distances[destinationNode] = newDistance;
}
unsettled.add(destinationNode);
}
}
}
}
31
DijkstraAlgorithmSet dijkstrasAlgorithm = new DijkstraAlgorithmSet(number_of_vertices);
dijkstrasAlgorithm.dijkstra_algorithm(adjacency_matrix, source);
32
EXPERIMENT 11 - PRIM’S ALGORITHM
AIM:
Write a java program that implements Prim’s algorithm to generate minimum cost spanning tree.
DESCRIPTION:
Prim's algorithm is a greedy algorithm that finds a minimum spanning tree for a 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 the edges in the tree is minimized. The algorithm operates by building this tree one vertex at a time, from an
arbitrary starting vertex, at each step adding the cheapest possible connection from the tree to another vertex.
PROGRAM:
import java.util.InputMismatchException;
import java.util.Scanner;
33
}
while (getUnsettledCount(unsettled) != 0)
{
evaluationVertex = getMimumKeyVertexFromUnsettled(unsettled);
unsettled[evaluationVertex] = false;
settled[evaluationVertex] = true;
evaluateNeighbours(evaluationVertex);
}
}
private int getMimumKeyVertexFromUnsettled(boolean[] unsettled2)
{
int min = Integer.MAX_VALUE;
int node = 0;
for (int vertex = 1; vertex <= numberofvertices; vertex++)
{
if (unsettled[vertex] == true && key[vertex] < min)
{
node = vertex;
min = key[vertex];
}
}
return node;
}
34
{
try
{
System.out.println("Enter the number of vertices");
number_of_vertices = scan.nextInt();
adjacency_matrix = new int[number_of_vertices + 1][number_of_vertices + 1];
35
if (i == j)
{
adjacency_matrix[i][j] = 0;
continue;
}
if (adjacency_matrix[i][j] == 0)
{
adjacency_matrix[i][j] = INFINITE;
}
}
}
Prims prims = new Prims(number_of_vertices);
prims.primsAlgorithm(adjacency_matrix);
prims.printMST();
36
EXPERIMENT 12 - KRUSKAL’S ALGORITHM
AIM:
Write a java program that implements Kruskal’s algorithm to generate minimum cost spanning tree.
DESCRIPTION:
Kruskal's algorithm is a minimum-spanning-tree algorithm which finds an edge of the least possible weight that
connects any two trees in the forest.[1] It is a greedy algorithm in graph theory as it finds a minimum spanning
tree for a connected weighted graph adding increasing cost arcs at each step.[1] This means 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 (a minimum spanning tree for
each connected component).
PROGRAM:
// Java program for Kruskal's algorithm to find Minimum
// Spanning Tree of a given connected, undirected and
// weighted graph
import java.util.*;
import java.lang.*;
import java.io.*;
class Graph
{
// A class to represent a graph edge
class Edge implements Comparable<Edge>
{
int src, dest, weight;
37
Graph(int v, int e)
{
V = v;
E = e;
edge = new Edge[E];
for (int i=0; i<e; ++i)
edge[i] = new Edge();
}
return subsets[i].parent;
}
38
{
Edge result[] = new Edge[V]; // Tnis will store the resultant MST
int e = 0; // An index variable, used for result[]
int i = 0; // An index variable, used for sorted edges
for (i=0; i<V; ++i)
result[i] = new Edge();
39
// Else discard the next_edge
}
// Driver Program
public static void main (String[] args)
{
40
graph.edge[3].dest = 3;
graph.edge[3].weight = 15;
graph.KruskalMST();
}
}
OUTPUT:
Following are the edges in the constructed MST
2 -- 3 == 4
0 -- 3 == 5
0 -- 1 == 10
41
EXPERIMENT 13 - FLOYD’S ALGORITHM
AIM:
Write a java program to implement Floyd’s algorithm for the all pairs shortest path problem.
DESCRIPTION:
Floyd–Warshall algorithm is an algorithm for finding shortest paths in a weighted graph with positive or
negative edge weights (but with no negative cycles).[1][2] A single execution of the algorithm will find the
lengths (summed weights) of shortest paths between all pairs of vertices. Although it does not return details of
the paths themselves, it is possible to reconstruct the paths with simple modifications to the algorithm. Versions
of the algorithm can also be used for finding the transitive closure of a relation , or (in connection with
the Schulze voting system) widest paths between all pairs of vertices in a weighted graph.
PROGRAM:
import java.util.PriorityQueue;
import java.util.List;
import java.util.ArrayList;
import java.util.Collections;
class Edge
{
public final Vertex target;
public final double weight;
public Edge(Vertex argTarget, double argWeight)
{ target = argTarget; weight = argWeight; }
}
42
public static void computePaths(Vertex source)
{
source.minDistance = 0.;
PriorityQueue<Vertex> vertexQueue = new PriorityQueue<Vertex>();
vertexQueue.add(source);
while (!vertexQueue.isEmpty()) {
Vertex u = vertexQueue.poll();
v.minDistance = distanceThroughU ;
v.previous = u;
vertexQueue.add(v);
}
}
}
}
Collections.reverse(path);
return path;
}
43
Vertex M = new Vertex("M");
Vertex O = new Vertex("O");
Vertex P = new Vertex("P");
Vertex R = new Vertex("R");
Vertex Z = new Vertex("Z");
OUTPUT:
Distance to Z: 49.0
Path: [A, M, R, P, Z]
44
EXPERIMENT 14 - 0/1 KNAPSACK PROBLEM
AIM:
Write a java program to implement Dynamic Programming algorithm for the 0/1 Knapsack problem.
DESCRIPTION:
Given weights and values of n items, put these items in a knapsack of capacity W to get the maximum total
value in the knapsack. In other words, given two integer arrays val[0..n-1] and wt[0..n-1] which represent values
and weights associated with n items respectively. Also given an integer W which represents knapsack capacity,
find out the maximum value subset of val[] such that sum of the weights of this subset is smaller than or equal
to W. You cannot break an item, either pick the complete item, or don’t pick it (0-1 property).
PROGRAM:
//This is the java program to implement the knapsack problem using Dynamic Programming
import java.util.Scanner;
return K[n][W];
}
45
Scanner sc = new Scanner(System.in);
System.out.println("Enter the number of items: ");
int n = sc.nextInt();
System.out.println("Enter the items weights: ");
int []wt = new int[n];
for(int i=0; i<n; i++)
wt[i] = sc.nextInt();
System.out.println("The maximum value that can be put in a knapsack of capacity W is: " +
knapSack(W, wt, val, n));
sc.close();
}
}
OUTPUT:
$ javac Knapsack_DP.java
$ java Knapsack_DP
46
EXPERIMENT 15 - OPTIMAL BINARY SEARCH TREE PROBLEM
AIM:
Write a java program to implement Dynamic Programming algorithm for the Optimal Binary Search Tree
Problem.
DESCRIPTION:
optimal binary search tree (Optimal BST), sometimes called a weight-balanced binary tree,[1] is a binary
search tree which provides the smallest possible search time (or expected search time) for a given sequence of
accesses (or access probabilities). Optimal BSTs are generally divided into two types: static and dynamic.
In the static optimality problem, the tree cannot be modified after it has been constructed. In this case, there
exists some particular layout of the nodes of the tree which provides the smallest expected search time for the
given access probabilities. Various algorithms exist to construct or approximate the statically optimal tree given
the information on the access probabilities of the elements.
PROGRAM:
import java.io.*;
import java.util.*;
class Optimal
{
public int p[];
public int q[];
public int a[];
public int w[][];
public int c[][];
public int r[][];
public int n;
int front,rear,queue[];
public Optimal(int SIZE)
{
p=new int[SIZE];
q= new int[SIZE];
a=new int[SIZE];
w=new int[SIZE][SIZE];
c=new int[SIZE][SIZE];
r=new int[SIZE][SIZE];
queue=new int[SIZE];
front=rear=-1;
}
/* This function returns a value in the range r[i][j-1] to r[i+1][j] SO that the cost c[i][k-1] + c[k][j] is
minimum */
47
int minimum = 32000;
for (m=r[i][j-1] ; m<=r[i+1][j] ; m++)
{
if ((c[i][m-1]+c[m][j]) < minimum)
{
minimum = c[i][m-1] + c[m][j];
k = m;
}
}
return k;
}
/* This function builds the table from all the given probabilities It basically computes C,r,W values */
/*This function builds the tree from the tables made by the OBST function */
48
{
int i, j, k;
System.out.print("The Optimal Binary Search Tree For The Given Nodes Is ....\n");
System.out.print("\n The Root of this OBST is :: "+r[0][n]);
System.out.print("\n The Cost Of this OBST is :: "+c[0][n]);
System.out.print("\n\n\tNODE\tLEFT CHILD\tRIGHT CHILD");
System.out.println("\n -------------------------------------------------------");
queue[++rear] = 0;
queue[++rear] = n;
while(front != rear)
{
i = queue[++front];
j = queue[++front];
k = r[i][j];
System.out.print("\n "+k);
if (r[i][k-1] != 0)
{
System.out.print(" "+r[i][k-1]);
queue[++rear] = i;
queue[++rear] = k-1;
}
else
System.out.print(" -");
if(r[k][j] != 0)
{
System.out.print(" "+r[k][j]);
queue[++rear] = k;
queue[++rear] = j;
}
else
System.out.print(" -");
}
System.out.println("\n");
}
}
/* This is the main function */
class OBSTDemo
{
public static void main (String[] args )throws IOException,NullPointerException
{
Optimal obj=new Optimal(10);
int i;
System.out.print("\n Optimal Binary Search Tree \n");
System.out.print("\n Enter the number of nodes ");
obj.n=getInt();
49
System.out.print("\n Enter the data as ....\n");
for (i=1;i<=obj.n;i++)
{
System.out.print("\n a["+i+"]");
obj.a[i]=getInt();
}
for (i=1 ; i<=obj.n ; i++)
{
System.out.println("p["+i+"]");
obj.p[i]=getInt();
}
for (i=0 ; i<=obj.n ; i++)
{
System.out.print("q["+i+"]");
obj.q[i]=getInt();
}
obj.OBST();
obj.build_tree();
}
50
OUTPUT:
Optimal Binary Search Tree
Enter the number of nodes 4
Enter the data as ....
a[1] 1
a[2] 2
a[3] 3
a[4] 4
p[1] 3
p[2] 3
p[3] 1
p[4] 1
q[0] 2
q[1] 3
q[2] 1
q[3] 1
q[4] 1
The Optimal Binary Search Tree For The Given Nodes Is ....
2 1 3
1 - -
3 - 4
4 - -
51
EXPERIMENT 16 - 0/1 KNAPSACK PROBLEM USING GREEDY METHOD
AIM:
Implement in Java, the 0/1 Knapsack problem using Greedy method.
DESCRIPTION:
The continuous knapsack problem (also known as the fractional knapsack problem) is
an algorithmic problem in combinatorial optimization in which the goal is to fill a container (the "knapsack")
with fractional amounts of different materials chosen to maximize the value of the selected materials.[1][2] It
resembles the classic knapsack problem, in which the items to be placed in the container are indivisible;
however, the continuous knapsack problem may be solved in polynomial time whereas the classic knapsack
problem is NP-hard.[1] It is a classic example of how a seemingly small change in the formulation of a problem
can have a large impact on its computational complexity.
PROGRAM:
import java.util.Scanner;
public class knapsacgreedy {
/**
* @param args
*/
public static void main(String[] args) {
int i,j=0,max_qty,m,n;
float sum=0,max;
Scanner sc = new Scanner(System.in);
int array[][]=new int[2][20];
System.out.println("Enter no of items");
n=sc.nextInt();
System.out.println("Enter the weights of each
items");
for(i=0;i<n;i++)
array[0][i]=sc.nextInt();
System.out.println("Enter the values of each
items");
for(i=0;i<n;i++)
array[1][i]=sc.nextInt();
System.out.println("Enter maximum volume of
knapsack :");
max_qty=sc.nextInt();
m=max_qty;
while(m>=0)
{
max=0;
for(i=0;i<n;i++)
{
if(((float)array[1][i])/((float)array[0][i])>max)
52
{
max=((float)array[1][i])/((float)array[0][i]);
j=i;
}
}
if(array[0][j]>m)
{
System.out.println("Quantity of item number: "
+ (j+1) + " added is " +m);
sum+=m*max;
m=-1;
}
else
{
System.out.println("Quantity of item
number: " + (j+1) + " added is " + array[0][j]);
m-=array[0][j];
sum+=(float)array[1][j];
array[1][j]=0;
}
15CSL47-Algorithms Lab IV Sem CSE
Dept. of CSE, CIT, Gubbi- 572 216 Page No.23
}
System.out.println("The total profit is " + sum);
sc.close();
}
}
OUTPUT:
Enter no of items
4
Enter the weights of each items
2132
Enter the values of each items
12
10
20
15
Enter maximum volume of knapsack :
5
Quantity of item number: 2 added is 1
Quantity of item number: 4 added is 2
Quantity of item number: 3 added is 2
The total profit is 38.333332
53