Summary: Cocktail sort is a variation of bubble sort

that is both a stable sorting algorithm and a comparison sort.

The algorithm differs from a bubble sort in that it sorts in both

directions on each pass through the list. This sorting algorithm

is only marginally more difficult to implement than a bubble sort,

and solves the problem of turtles in bubble sorts.

The various names of cocktail sort are bidirectional bubble sort,

cocktail shaker sort, shaker sort,

ripple sort, shuffle sort, shuttle sort or happy hour sort.

Complexity - O(n^2)

*/

#include

#define MAX 8

int main()

{

int data[MAX];

int i, j, n, c;

printf("\nEnter the data");

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

{

scanf("%d", &data[i]);

}

n = MAX;

do

{

/*Rightward pass will shift the largest

element to its correct place at the end*/

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

{

if (data[i] > data[i + 1])

{

data[i] = data[i] + data[i + 1];

data[i + 1] = data[i] - data[i + 1];

data[i] = data[i] - data[i + 1];

}

}

n = n - 1;

/* Leftward pass will shift the smallest element to

its correct place at the beginning*/

for (i= MAX - 1, c = 0; i >= c; i--)

{

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

{

data[i] = data[i] + data[i - 1];

data[i - 1] = data[i] - data[i - 1];

data[i] = data[i] - data[i - 1];

}

}

c = c + 1;

} while (n != 0 && c != 0);

printf("The sorted elements are:");

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

{

printf("%d\t", data[i]);

}

}

_______________________________OUPUT______________________________

Enter the data 12

342

4

563

43

5

3

2

The sorted elements are:2 3 4 5 12 43 342 563

--------------------------------

Post Views: 821