Cocktail sort: diferenças entre revisões
Aspeto
Conteúdo apagado Conteúdo adicionado
Linha 56: | Linha 56: | ||
}//fecha while |
}//fecha while |
||
}// fim da funçao</source> |
}// fim da funçao</source> |
||
Para visualizar a esquematização 3D, copie e cole no navegador o seguinte site: |
|||
* www.own3d.es |
|||
===Código em C#=== |
===Código em C#=== |
Revisão das 19h17min de 25 de maio de 2010
Esta página ou seção carece de contexto.Fevereiro de 2008) ( |
Cocktail sort ou Shaker Sort
Este metodo de ordenação funciona como o Bubble Sort, mas de forma bidirecional e também é conhecido como Shaker Sort.
Complexidade
O(n²)
Implementações
Código em C
void cocktail_sort(int list[10]) {
int length,bottom,top, swapped,i,aux;
length=10;
bottom = 0;
top = length - 1;
swapped = 0;
while(swapped == 0 && bottom < top)//Se não houver troca de posições ou o ponteiro que
{ //sobe ultrapassar o que desce, o vetor esta ordenado
swapped = 1;
//Este for é a “ida” para a direita
for(i = bottom; i < top; i = i + 1)
{
if(list[i] > list[i + 1]) //indo pra direita:testa se o próximo é maior
{ //indo pra direita:se o proximo é maior que o atual,
//troca as posições
aux=list[i];
list[i]=list[i+1];
list[i+1]=aux;
swapped = 0;
}
}//fecha for
// diminui o `top` porque o elemento com o maior valor
// já está na direita (atual posição top)
top = top - 1;
//Este for é a “ida” para a esquerda
for(i = top; i > bottom; i = i - 1)
{ if(list[i] < list[i - 1])
{
aux=list[i];
list[i]=list[i-1];
list[i-1]=aux;
swapped = 0;
}
}
//aumenta o `bottom` porque o menor valor já está
//na posição inicial (bottom)
bottom = bottom + 1;
}//fecha while
}// fim da funçao
Para visualizar a esquematização 3D, copie e cole no navegador o seguinte site:
- www.own3d.es
Código em C#
private static void cocktail(int[] vetor)
{
int tamanho, inicio, fim, swap, aux;
tamanho = 19; // para um vetor de 20 elementos
inicio = 0;
fim = tamanho - 1;
swap = 0;
while (swap == 0 && inicio < fim)
{
swap = 1;
for (int i = inicio; i < fim; i = i + 1)
{
if (vetor[i] > vetor[i + 1])
{
aux = vetor[i];
vetor[i] = vetor[i + 1];
vetor[i + 1] = aux;
swap = 0;
}
}
fim = fim - 1;
for (int i = fim; i > inicio; i = i - 1)
{
if (vetor[i] < vetor[i - 1])
{
aux = vetor[i];
vetor[i] = vetor[i - 1];
vetor[i - 1] = aux;
swap = 0;
}
}
inicio = inicio + 1;
}
}
Código em Pascal
procedure ShakerSort(var A:vetor; n:integer);
var L,R,k,i:integer;
begin
L:=2;
R:=n;
k:=2;
repeat
for i:=L to R do
begin
if A[i-1]>A[i] then
begin
aux := A[i-1];
A[i-1] := A[i];
A[i]:= aux;
k:=i;
end;
end;
R:=k-1;
for i:=R downto L do
begin
if A[i-1]>A[i] then
begin
aux := A[i-1];
A[i-1] := A[i];
A[i]:= aux;
k:=i;
end;
end;
L:=k+1;
until L>R;
end;
Código em Ruby
def sort(array)
swap = true
begining = 0
ending = array.length-1
while(swap)
swap = false
begining.upto ending-1 do |i|
if(array[i] > array[i+1])
aux = array[i]
array[i] = array[i+1]
array[i+1] = aux
swap = true
end
end
ending -= 1
ending.downto begining+1 do |i|
if(array[i] < array[i-1])
aux = array[i]
array[i] = array[i-1]
array[i-1] = aux
swap = true
end
end
begining += 1
end
return array
end