Loading presentation...

Present Remotely

Send the link below via email or IM

Copy

Present to your audience

Start remote presentation

  • Invited audience members will follow you as you navigate and present
  • People invited to a presentation do not need a Prezi account
  • This link expires 10 minutes after you close the presentation
  • A maximum of 30 users can follow your presentation
  • Learn more about this feature in our knowledge base article

Do you really want to delete this prezi?

Neither you, nor the coeditors you shared it with will be able to recover it again.

DeleteCancel

Make your likes visible on Facebook?

Connect your Facebook account to Prezi and let your likes appear on your timeline.
You can change this under Settings & Account at any time.

No, thanks

Método Quick Sort

No description
by

Nhikona Drinking Cofee

on 31 May 2013

Comments (0)

Please log in to add your comment.

Report abuse

Transcript of Método Quick Sort

METODO QUICK SORT Equipo 8 El método de ordenación quicksort es actualmente el más eficiente y veloz de los métodos de ordenación interna. Es tambien conocido como método rapido y de ordenamiento por partición. Este método es una mejora sustancial del método de intercambio directo y se denomina quicksort-rapido-por la velocidad que ordena los elementos del arreglo. Su autor, C. A. Hoare, lo llamo así.

La idea central de este algoritmo consiste en lo siguente: Charles Antony Richard Hoare ALGORITMO

1. Se toma un elemento x (pivote) de una posición cualquiera del arreglo.

2. Se trata de ubicar a x en la posición correcta del arreglo, de tal forma que todos los elementos que se encuentran a su izquierda sean menores o iguales a x y todos los que se encuentran a su derecha sean menores o iguales a x.

3. Se repiten los pasos anteriores, pero ahora para los conjutos de datos que se encuentran a la izquierda y a la derecha de la posición de x en el arreglo.

4. El proceso termina cuando todos los elementos se encuentran en su posición correcta en el arreglo. "GRACIAS :D" Pivote i d 4 5 2 3 1 i d
A: 15 67 08 16 44 27 12 35
p
recorrido de derecha a izquierda

izq der
A: 15 67 08 16 44 27 12 35

15 es mayor que 35 no hay intercambio
15 es mayor que 12 si hay intercambio

recorrida de izquierda a derecha

A: 12 67 08 16 44 27 15 35

15 es menor que 67 si hay intercambio

recorrido de derecha a izquierda

A: 12 15 08 16 44 27 67 35

15 es mayoy que 27 no hay intercambio
15 es mayor que 44 no hay intercambio
15 es mayor que 16 no hay intercambio
15 es mayor que 08 si hay intercambio
A: 12 08 15 16 44 27 67 35
Pivote ya esta en su posición
A: 12 08 15 16 44 27 67 35
recorrida de derecha a izquierda
44 es mayor que 35 si hay intercambio
A: 12 08 15 16 35 27 67 44
recorrida de izquierda a derecha
44 es menor que 27 no hay intercambio
44 es menor que 67 si hay intercambio
A: 12 08 15 16 35 27 44 67
recorrida de derecha a izquierda
35 es mayor que 27 si hay intercambio
A: 12 08 15 16 27 35 44 67

A: 08 12 15 16 27 35 44 67 ORDENADO CODIGO


public void QuickSort(int[] A, int izq, int der){
if(izq < der) { // meter valores a los otros metodos
int k = Particionar(A, izq, der);
QuickSort(A, izq, k);
QuickSort(A, k+1 , der);
}
}
// es el que compara de i a d asigna el pivote
private int Particionar(int[] A, int izq , int der){
int piv = A[izq], i = izq, j = der;

while(i < j){
while(A[i] < piv){
i++;
}
while(A[j] > piv){
j--;
}
if(i < j)
Swap(A, i++, j--);// intercambia
}
return j;
}
// aqui intercambia y sustituye
private void Swap(int[] A, int i, int j){
int aux = A[i];
A[i] = A[j];
A[j] = aux;
}
Full transcript