ALGORITHM LAB Manual
ALGORITHM LAB Manual
Find the minimum cost spanning tree of a given undirected graph using Prim’s
8. algorithm.
Develop a program to find out the maximum and minimum numbers in a given list
11. of n numbers using the divide and conquer technique.
Implement Merge sort and Quick sort methods to sort an array of elements and
determine the time required to sort. Repeat the experiment for different values of
12.
n, the number of elements in the list to be sorted and plot a graph of the time taken
versus n.
13 Implement N Queens problem using Backtracking.
Implement any scheme to find the optimal solution for the Traveling Salesperson
14 problem and then solve the same problem instance using any approximation
algorithm and determine the error in the approximation.
15 Implement randomized algorithms for finding the kth smallest number.
Ex.No.1 LINEAR SEARCH
Date:
Aim
To Implement Linear Search and calculate the time required to search for an
element.
Algorithm
1. Step 1: set pos = -1 2. Step 2: set i = 1 3. Step 3: repeat step 4
while i <= n 4. Step 4: if a[i] == val 5. set pos = i 6. print pos 7. go
to step 6 8. [end of if] 9. set ii = i + 1 10. [end of loop] 11. Step 5: if
pos = -1 12. print "value is not present in the array " 13. [end of if] 14.
Step 6: exit
Program // Online C compiler to run C program online
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
#define max 20 int
pos;
int linsearch (int,int[],int);
void main()
{ intch=1; double t; int n,i,a [max],k,op,low,high,pos;
clock_tbegin,end,ctime; double cpu_time_used;
begin=clock(); end=clock(); while(ch) {
printf("\n.......MENU ...... \n 1.Linear search \n 2.Exit \n");
printf("\n enter your choice\n"); scanf("%d",&op);
switch(op) {
case 1:printf("\n enter the number of elements \n"); scanf("%d",&n);
printf("\n enter the elements of an array\n");
for(i=0;i<n;i++) scanf("%d",&a[i]);
printf("\n enter the element to be searched \n");
scanf("%d",&k);
begin=clock();
pos=linsearch(n,a,k);
end=clock(); if(pos==-1)
printf("\n\n Unsuccessful search");
else printf("element %d is found at position
%d",k,pos+1); ctime=(end-begin)/cpu_time_used;
printf("\n Time taken is %ld CPU cycles \n",ctime);
break;
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to execute the linear Search was executed successfully
Output:
EX NO:2 RECURSIVE BINARY SEARCH
DATE:
AIM:
To Implement the recursive binary search and calculate the CPU running time of the algorithm.
ALGORITHM
1. Compare x with the middle element.
2. If x matches with middle element, we return the mid index.
3. Else If x is greater than the mid element, then x can only lie in right half subarray
after the mid element. So we recur for right half.
4. Else (x is smaller) recur for the left half.
PROGRAM CODE:
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
#define max 20 int
pos;
int binsearch (int,int[],int,int,int); int
linsearch (int,int[],int);
void main()
{ intch=1; double t; int n,i,a [max],k,op,low,high,pos;
long tick1,tick2; long elapsed=tick2-tick1;
double elapsed_time = ((double)elapsed/CLOCKS_PER_SEC);
while(ch) {
printf("\n.......MENU ...... \n 1.BinarySearch \n 2.Linear search \n 3.Exit \n");
printf("\n enter your choice\n");
scanf("%d",&op); switch(op)
{
case 1:printf("\n enter the number of elments\n"); scanf("%d",&n);
printf("\n enter the number of an array in the order \n");
for(i=0;i<n;i++) scanf("%d",&a[i]);
printf("\n enter the elements to be searched \n");
scanf("%d",&k); low=0;high=n-1; tick1=clock();
pos=binsearch(n,a,k,low,high); tick2=clock();
if(pos==-1)
printf("\n\nUnsuccessful search");
else
printf("\n element %d is found at position %d",k,pos+1);
}
int binsearch(int n,int a[],int k,intlow,int high)
{ int mid;
mid=(low+high)/2
; if(low>high)
return -1;
if(k==a[mid])
return(mid); else
if(k<a[mid])
return binsearch(n,a,k,low,mid-1); else
return binsearch(n,a,k,mid+1,high);
}
int linsearch(int n,int a[],int k)
{ if(n<0) return -
1;
if(k==a[n-1])
return (n-1);
else
return linsearch(n-1,a,k);
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to implement the recursive binary search was executed successfully.
Output:
EX NO:3 NAÏVE PATTERN SEARCH
DATE
AIM:
ToperformGiven a text txt [0...n-1] and a pattern pat [0...m-1], write a function
search (char pat [ ], char txt [ ]) that prints all occurrences of pat [ ] in txt [ ].
ALGORITHM
1. n ← length [T]
2. m ← length [P]
3. fOr s ← 0 tO n -m
4. do if P [1.....m] = T [s + 1. .. s + m]
5. then print "Pattern occurs with shift"
PROGRAM CODE:
int main()
{
char txt[] = "AABAACAADAABAAABAA";
char pat[] = "AABA"; search(pat, txt); return
0;
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the naïve pattern matching algorithm was implemented successfully
EX NO :4a INSERTION SORT
DATE
AIM
To Sort a given set of elements using the Insertion sort method and determine the time
required to sort the elements.
ALGORITHM
1. Iterate from arr[1] to arr[N] over the array.
2. Compare the current element (key) to its predecessor.
3. If the key element is smaller than its predecessor, compare it to the elements
before. Move the greater elements one position up to make space for the
swapped element.
PROGRAM
#include <math.h>
#include <stdio.h>
#include <time.h>
/* Function to sort an array using insertion sort*/ void
insertionSort(int arr[], int n)
{ sleep(4); int i, key, j; for (i
= 1; i< n; i++) {
key = arr[i];
j = i - 1;
while (j >= 0 &&arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key;
}
}
void printArray(int arr[], int n)
{
int i;
for (i = 0; i< n; i++)
printf("%d ", arr[i]);
printf("\n");
} int
main()
{
long tick1,tick2; int arr[] = { 12, 11,
13, 5, 6 }; int n = sizeof(arr) /
sizeof(arr[0]);
tick1 = clock(); insertionSort(arr,
n); tick2 = clock(); long
elapsed = tick2-tick1;
double elapsed_time = ((double)elapsed/CLOCKS_PER_SEC); printArray(arr,
n);
printf("Time taken by the CPU is %lf seconds \n",elapsed_time);
return 0; }
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to sort a given set of elements using the Insertion sort method and
determine the time required to sort the elements
EX NO :4b HEAP SORT
DATE
AIM
To Sort a given set of elements using the Heap sort method and determine the time
required to sort the elements.
ALGORITHM
1. First convert the array into heap data structure using heapify, then one by one delete the
root node of the Max-heap and replace it with the last node in the heap and then heapify
the root of the heap. Repeat this process until size of heap is greater than 1.
2. Build a heap from the given input array.
3. Repeat the following steps until the heap contains only one element:
a. Swap the root element of the heap (which is the largest element)
with the last element of the heap
b. Remove the last element of the heap (which is now in the correct
position).
c. Heapify the remaining elements of the heap. 4. The sorted array
is obtained by reversing the order of the elements in the input
array.
PROGRAM
#include <stdio.h>
#include<time.h>
void main()
{
int heap[10], num, i, j, c, rootElement, tempVar; long
tick1,tick2;
printf("\n Enter num of elements :");
scanf("%d", &num);
printf("\n Enter the nums : ");
for (i = 0; i< num; i++)
scanf("%d", &heap[i]); for (i
= 1; i< num; i++)
{ c = i;
do
{ rootElement = (c - 1) / 2;
if (heap[rootElement] < heap[c]) /* to create MAX heap array */ {
tempVar = heap[rootElement];
heap[rootElement] = heap[c];
heap[c] = tempVar;
}c=
rootElement;
} while (c != 0);
} tick1=clock();
printf("Heap array : "); for
(i = 0; i< num; i++)
printf("%d\t ", heap[i]); for
(j = num - 1; j >= 0; j--)
{ tempVar =
heap[0]; heap[0] =
heap[j]; heap[j] =
tempVar;
rootElement = 0;
do
{ c = 2 * rootElement + 1; if ((heap[c]
<heap[c + 1]) && c < j-1) c++;
if (heap[rootElement]<heap[c] && c<j) {
tempVar = heap[rootElement];
heap[rootElement] = heap[c];
heap[c] = tempVar;
} rootElement =
c;
} while (c < j);
} printf("\n The sorted array is :
"); for (i = 0; i< num; i++)
printf("\t %d", heap[i]); tick2-
clock(); long elapsed = tick2-
tick1;
double elapsed_time = ((double)elapsed/CLOCKS_PER_SEC);
printf("Time taken by the CPU is %lf seconds \n",elapsed_time); }
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to implement heap sort was executed successfully
EX NO :5 BREADTH FIRST SEARCH
DATE:
AIM
To Develop a program to implement graph traversal using Breadth First Search
ALGORITHM
1. Start by putting any one of the graph's vertices at the back of a queue.
2. Take the front item of the queue and add it to the visited list.
3. Create a list of that vertex's adjacent nodes. Add the ones which aren't in the visited list to
the back of the queue.
4. Keep repeating steps 2 and 3 until the queue is empty.
PROGRAM
#include <stdio.h>
#include <stdlib.h>
#define SIZE 40
struct queue
{ int
items[SIZE]; int
front; int rear;
};
struct node {
int vertex; struct
node* next;
}; struct node*
createNode(int);
struct Graph {
int numVertices;
struct node** adjLists;
int* visited;
};
graph->visited[startVertex] = 1;
enqueue(q, startVertex);
while (!isEmpty(q)) {
printf("Visited %d\n", currentVertex); struct node*
temp = graph->adjLists[currentVertex];
while (temp) {
int adjVertex = temp->vertex;
if (graph->visited[adjVertex] == 0) {
graph->visited[adjVertex] = 1;
enqueue(q, adjVertex);
}
temp = temp->next;
}
}
}
return graph;
}
return graph;
}
if (isEmpty(q)) {
printf("Queue is empty");
} else { printf("\nQueue contains \n");
for (i = q->front; i< q->rear + 1; i++) {
printf("%d ", q->items[i]);
}
}
}
int main() {
struct Graph* graph = createGraph(6);
addEdge(graph, 0, 1); addEdge(graph,
0, 2); addEdge(graph, 1, 2);
addEdge(graph, 1, 4);
addEdge(graph, 1, 3);
addEdge(graph, 2, 4);
addEdge(graph, 3, 4);
bfs(graph, 0);
return 0;
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to implement the breadth first search was executed successfully.
EX NO :6 DEPTH FIRST SEARCH
DATE:
AIM
To Implement the Graph traversal using depth first search.
ALGORITHM
PROGRAM
#include <stdio.h>
#include <stdlib.h>
// Globally declared visited array
int vis[100];
// Graph structure to store number
// of vertices and edges and
// Adjacency matrix struct
Graph {
int V; int
E; int**
Adj;
};
// Function to input data of graph
struct Graph* adjMatrix()
{ struct Graph* G = (struct Graph*)
malloc(sizeof(struct Graph)); if (!G)
{ printf("Memory Error\n");
return NULL;
}
G->V = 7;
G->E = 7;
G->Adj = (int**)malloc((G->V) * sizeof(int*));
for (int k = 0; k < G->V; k+
return G;
}// DFS function to print DFS traversal of graph
void DFS(struct Graph* G, int u)
{ vis[u] = 1; printf("%d ", u); for (int v = 0; v
< G->V; v++) { if (!vis[v] && G-
>Adj[u][v]) { DFS(G, v);
}
}
}
// Function for DFS traversal void
DFStraversal(struct Graph* G)
{ for (int i = 0; i< 100; i++) {
vis[i] = 0;
}
for (int i = 0; i< G->V; i++) { if
(!vis[i]) {
DFS(G, i);
}}}
// Driver code void
main()
{ struct Graph* G; G =
adjMatrix();
DFStraversal(G);
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to implement the graph traversal using depth first search was
completed successful
SAMPLE OUTPUT
EX NO :7 DIJIKSTRA’S ALGORITHM
DATE:
AIM
To implement a program to find the shortest paths to other vertices using Dijkstra’s
algorithm.
ALGORITHM
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.
PROGRAM
#include <limits.h>
#include <stdbool.h>
#include <stdio.h>
// driver's code
int main() {
/* Let us create the example graph discussed above */
int graph[V][V] = { { 0, 4, 0, 0, 0, 0, 0, 8, 0 },
{ 4, 0, 8, 0, 0, 0, 0, 11, 0 },
{ 0, 8, 0, 7, 0, 4, 0, 0, 2 },
{ 0, 0, 7, 0, 9, 14, 0, 0, 0 },
{ 0, 0, 0, 9, 0, 10, 0, 0, 0 },
{ 0, 0, 4, 14, 10, 0, 2, 0, 0 },
{ 0, 0, 0, 0, 0, 2, 0, 1, 6 },
{ 8, 11, 0, 0, 0, 0, 1, 0, 7 },
{ 0, 0, 2, 0, 0, 0, 6, 7, 0 } };
// Function call
dijkstra(graph, 0);
return 0;
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to implement the shortest paths to other vertices using Dijkstra’s
algorithm was executed successfully.
EX NO :8 PRIM’S ALGORITHM
DATE:
AIM
To implement the minimum cost spanning tree of a given undirected graph using Prim’s
algorithm.
ALGORITHM
Step 1: Determine an arbitrary vertex as the starting vertex of the MST.
Step 2: Follow steps 3 to 5 till there are vertices that are not included in the MST (known
as fringe vertex).
Step 3: Find edges connecting any tree vertex with the fringe vertices.
Step 4: Find the minimum among these edges.
Step 5: Add the chosen edge to the MST if it does not form any cycle.
Step 6: Return the MST and exit
PROGRAM
#include <limits.h>
#include <stdbool.h>
#include <stdio.h> #define
V5
int minKey(int key[], bool mstSet[])
{
// Initialize min value
int min = INT_MAX, min_index;
return min_index;
}
// Driver's code
int main()
{
int graph[V][V] = { { 0, 2, 0, 6, 0 },
{ 2, 0, 3, 8, 5 },
{ 0, 3, 0, 0, 7 },
{ 6, 8, 0, 0, 9 },
{ 0, 5, 7, 9, 0 } };
return 0;
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
This the program to implement the minimum cost spanning tree of a given undirected
graph using Prim’s algorithm.
EX NO :9 FLOYD’S ALGORITHM
DATE:
AIM
To implement Floyd’s algorithm for the All-Pairs- Shortest-Paths problem
ALGORITHM:
1. Initialize the solution matrix same as the input graph matrix as a first step.
2. Then update the solution matrix by considering all vertices as an intermediate vertex.
3. 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.
4. When we pick vertex number k as an intermediate vertex, we already have considered
vertices {0, 1, 2, .. k-1} as intermediate vertices.
5. For every pair (i, j) of the source and destination vertices respectively, there are two
possible cases. o k is not an intermediate vertex in shortest path from i to j. We keep
the value of dist[i][j] as it is.
o 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
// C Program for Floyd Warshall Algorithm
#include <stdio.h>
}
}
// driver's code
int main()
{ int graph[V][V] = { { 0, 5, INF, 10 },
{ INF, 0, 3, INF },
{ INF, INF, 0, 1 },
{ INF, INF, INF, 0 } };
// Function call
floydWarshall(graph);
return 0;
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to implement Floyd’s algorithm for the All-Pairs- Shortest-Paths
problem was executed successfully.
EX NO :10 WARSHALL’S ALGORITHM
DATE
AIM:
To implement the transitive closure of a given directed graph using Warshall's algorithm
ALGORITHM
#include<stdio.h>
#include<math.h> int
max(int, int);
void warshal(int p[10][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] = max(p[i][j],
p[i][k] && p[k][j]);
}
int max(int a, int b) {
;
if (a > b)
return (a);
else return
(b);
} void main() { int p[10][10] = { 0 },
n, e, u, v, i, j;
printf("\n Enter the number of vertices:");
scanf("%d", &n);
printf("\n Enter the number of edges:");
scanf("%d", &e); for (i =
1; i<= e; i++) {
printf("\n Enter the end vertices of edge %d:", i);
scanf("%d%d", &u, &v);
p[u][v] = 1;
} printf("\n Matrix of input data:
\n"); for (i = 1; i<= n; i++) { for (j
= 1; j <= n; j++)
printf("%d\t", p[i][j]); printf("\n");
} warshal(p,
n);
printf("\n Transitive closure: \n");
for (i = 1; i<= n; i++) { for (j =
1; j <= n; j++)
printf("%d\t", p[i][j]);
printf("\n"); }
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the transitive closure of a given directed graph using Warshall's algorithm was
executed successfully.
EX NO :11 FINDING MAXIMUM AND MINIMUM NUMBERS IN ARRAY
DATE
AIM
To implement a program to find out the maximum and minimum numbers in a given list
of n numbers using the divide and conquer technique.
ALGORITHM
1. Create two intermediate variables max and min to store the maximum and
minimum element of the array.
2. Assume the first array element as maximum and minimum both, say max =
arr[0] and min = arr[0].
3. Traverse the given array arr[].
4. If the current element is smaller than min, then update the min as the current
element. 5. If the current element is greater than the max, then update the max as the
current element.
6. Repeat the above two steps 4 and 5 for the element in the array.
PROGRAM
#include<stdio.h>
#include<stdio.h>
int max, min; int
a[100];
void maxmin(int i, int j)
{ int max1, min1,
mid;
if(i==j)
{ max = min =
a[i];
} else
{ if(i ==
j-1)
{ if(a[i]
<a[j])
{ max =
a[j]; min =
a[i];
}
else
{ max =
a[i]; min =
a[j];
}
}
else
{ mid =
(i+j)/2;
maxmin(i, mid);
max1 = max; min1 = min;
maxmin(mid+1, j);
if(max <max1)
max = max1;
if(min > min1)
min = min1;
} }} int
main ()
{ int i,
num;
printf ("\nEnter the total number of numbers : ");
scanf ("%d",&num); printf
("Enter the numbers : \n");
for (i=1;i<=num;i++)
scanf ("%d",&a[i]);
max = a[0]; min
= a[0];
maxmin(1, num); printf ("Minimum element in an
array : %d\n", min); printf ("Maximum element in an
array : %d\n", max); return 0;
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to find out the maximum and minimum numbers in a given list of n
numbers using the divide and conquer technique was executed successfully.
Output:
EX NO :12A MERGE SORT
DATE
AIM
To Implement merge sort methods to sort an array of elements and determine the time
required to sort.
ALGORITHM
step 1: start
step 2: declare array and left, right, mid variable
step 3: perform merge function.
if left > right
return
mid= (left+right)/2 mergesort(array,
left, mid) mergesort(array, mid+1,
right) merge(array, left, mid, right)
step 4: Stop
PROGRAM
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
merge(arr, l, m, r);
}
}
// UTILITY FUNCTIONS
// Function to print an array void
printArray(int A[], int size)
{
int i;
for (i = 0; i< size; i++)
printf("%d ", A[i]);
printf("\n");
}
// Driver code
int main()
{ long tick1,tick2; int arr[] = {12, 11,
13, 5, 6, 7};
int arr_size = sizeof(arr) / sizeof(arr[0]);
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the Implementation of merge sort to sort an array of elements and the time required
was executed and determined successfully.
Output:
EX NO :12B QUICK SORT
DATE:
AIM
To Implement Quick sort methods to sort an array of elements and determine the time
required to sort.
ALGORITHM
Step 1 − Pick an element from an array, call it as pivot element.
Step 2 − Divide an unsorted array element into two arrays.
Step 3 − If the value less than pivot element come under first sub array, the remaining
elements with value greater than pivot come in second sub array.
PROGRAM
#include<stdio.h> #include
<time.h>
void quicksort(int number[25],int first,int last){
int i, j, pivot, temp;
sleep(10); if(first<last){
pivot=first;
i=first; j=last;
while(i<j){
while(number[i]<=number[pivot]&&i<last)
i++; while(number[j]>number[pivot])
j--;
if(i<j){
temp=number[i];
number[i]=number[j];
number[j]=temp;
}
}
temp=number[pivot];
number[pivot]=number[j];
number[j]=temp; quicksort(number,first,j-
1); quicksort(number,j+1,last);
}
} int
main(){ int
i, count,
number[25
]; long
tick1,tick2
;
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the Implementation of Quick sort to sort an array of elements and the time required
to sort was executed and determined successfully.
Output:
EX NO :13 N-QUEENS PROBLEM
DATE:
AIM
To Implement N Queens problem using Backtracking
ALGORITHM
1. Initialize an empty chessboard of size NxN.
2. Start with the leftmost column and place a queen in the first row of that column.
3. Move to the next column and place a queen in the first row of that column.
4. Repeat step 3 until either all N queens have been placed or it is impossible to place a
queen in the current column without violating the rules of the problem.
5. If all N queens have been placed, print the solution.
6. If it is not possible to place a queen in the current column without violating the rules of
the problem, backtrack to the previous column.
7. Remove the queen from the previous column and move it down one row.
8. Repeat steps 4-7 until all possible configurations have been tried.
PROGRAM
#define N 4
#include <stdbool.h>
#include <stdio.h>
return true;
}
bool solveNQ()
{
int board[N][N] = { { 0, 0, 0, 0 },
{ 0, 0, 0, 0 },
{ 0, 0, 0, 0 },
{ 0, 0, 0, 0 } };
if (solveNQUtil(board, 0) == false) {
printf("Solution does not exist");
return false;
}
printSolution(board);
return true;
}
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus to Implement N Queens problem using Backtracking was executed successfully.
Output:
EX NO :14 TRAVELLING SALESPERSON PROBLEM
DATE:
AIM
To find the optimal solution for the Traveling Salesperson problem and then solve the
same problem instance using any approximation algorithm and determine the error in the
approximation.
ALGORITHM
1. Start on an arbitrary vertex as current vertex.
2. Find out the shortest edge connecting current vertex and an unvisited vertex V.
3. Set current vertex to V.
4. Mark V as visited.
5. If all the vertices in domain are visited, then terminate.
6. Go to step 2.
7. The sequence of the visited vertices is the output of the algorithm.
PROGRAM
#include<stdio.h> int
a[10][10],n,visit[10]; int
cost_opt=0,cost_apr=0; int
least_apr(int c); int
least_opt(int c);
int least_opt(int c)
{ int i,nc=999; int
min=999,kmin=999;
for(i=1;i<=n;i++)
{ if((a[c][i]!=0)&&(visit[i]==0))
if(a[c][i]<min)
{ min=a[i][1]+a[c][i];
kmin=a[c][i]; nc=i;
}
}
if(min!=999)
cost_opt+=kmin; return
nc;
}
int least_apr(int c)
{ int i,nc=999; int
min=999,kmin=999;
for(i=1;i<=n;i++)
{ if((a[c][i]!=0)&&(visit[i]==0))
if(a[c][i]<kmin) {
min=a[i][1]+a[c][i]; kmin=a[c][i]; nc=i;
}
} if(min!=999)
cost_apr+=kmin;
return nc;
} void
main()
{
int i,j;
printf("Enter No. of cities:\n");
scanf("%d",&n);
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the optimal solution for the Traveling Salesperson problem using approximation
algorithm was executed successfully.
Output:
EX NO :15 FINDING THE Kth SMALLEST NUMBER
DATE:
AIM
To implement randomized algorithms for finding the kth smallest number.
ALGORITHM
1. check if k>0&& k<=r-l+1:
#include<iostream>
#include<climits> #include<cstdlib>
using namespace std;
int randomPartition(int arr[], int l, int r);
// If position is same as
k if (pos-l == k-1)
return arr[pos];
if (pos-l > k-1) // If position is more, recur for left subarray
return kthSmallest(arr, l, pos-1, k);
PROGRAM 50
VIVA 10
OUTPUT 20
TOTAL 100
RESULT
Thus the program to implement randomized algorithms for finding the kth smallest
number was executed successfully.
Output: