Metodos para ordenar vectores

Páginas: 3 (504 palabras) Publicado: 17 de diciembre de 2013
METODOS PARA ORDENAR VECTORES
1 ShellSort
Este método funciona de la siguiente manera:
Ordena subgrupos de elementos separados K unidades (respecto de su posición en el arreglo) del arreglooriginal. El valor K es llamado incremento.
Después de que los primeros K subgrupos han sido ordenados, se escoge un nuevo valor de K más pequeño, y el arreglo es de nuevo partido entre el nuevo conjuntode subgrupos. Cada uno de los subgrupos mayores es ordenado y el proceso se repite de nuevo con un valor más pequeño de K.
Eventualmente el valor de K llega a ser 1, de tal manera que el subgrupoconsiste de todo el arreglo ya casi ordenado.
Al principio del proceso se escoge la secuencia de decrecimiento de incrementos; el último valor debe ser 1.
Cuando el incremento toma un valor de 1,todos los elementos pasan a formar parte del subgrupo y se aplica inserción directa.
El método se basa en tomar como salto N/2 (siendo N el número de elementos) y luego se va reduciendo a la mitad encada repetición hasta que el salto o distancia vale 1. Algoritmo:
void shellSort(int a[], int h)
{
  int i;
  while (h > 0)
  { for (i = h-1; i= h) && (a[j - h] > B); j -= h)
       { a[j] = a[j -h];} 
         a[j] = B;
     }
       h = h / 2;
  }
2 MergeSort
El algoritmo Merge divide el arreglo original en dos arreglos y los coloca en arreglos separados. Cada arreglo es recursivamenteordenado y finalmente se unen los arreglos en un arreglo ordenado. Como cualquiera de los algoritmos de ordenamiento recursivo el algoritmo Merge tiene complejidad de O(n log n). Fue desarrollado porJohn Von Neumann. Algoritmo.-
void ordenarMezcla(TipoEle A[], int izq, int der)
{ if ( izq < der )
  { centro = ( izq + der ) % 2; 
    ordenarMezcla( A, izq, centro );
    ordenarMezcla( A,centro+1, der);
    intercalar( A, izq, centro, der ); 
  }
}
void intercalar(TipoEle A[], int a, int c, int b )
{ k = 0;
  i = a;
  j = c + 1;
  n = b - a;
  while ( i < c + 1 ) && ( j < b +...
Leer documento completo

Regístrate para leer el documento completo.

Estos documentos también te pueden resultar útiles

  • Metodos De Ordenamiento De Matrices Y Vectores
  • Metodo de ordenamiento de vectores
  • Metodos Para Realizar Operaciones Con Vectores
  • Ordenamiento De Vectores
  • Métodos gráficos y analíticos para la suma de vectores
  • Métodos Numéricos Para Valores Y Vectores Propios
  • Métodos numéricos para resolver ecuaciones de 1er orden
  • metodos de ordenamiento

Conviértase en miembro formal de Buenas Tareas

INSCRÍBETE - ES GRATIS