Posted by : Jason miércoles, 1 de marzo de 2017

Metodo SHAKER o Sacudida

codigo:

#include<iostream>
#include <stdio.h>
#include <stdio.h>
#include <stdlib.h>
using namespace std;
//****************************** INSERTAR ************************************//

int *Insertar(int *A ,int N)
{
 for( int i = 0 ; i < N ; i++ )
    {
        cout<<endl<<"    - Ingrese el valor ["<<i + 1<<"] = ";
        cin>>A[i];
   
    }
 return A;  
}
//******************************* MOSTRAR ************************************//
void Mostrar(int *A ,int N)
{

 for( int i = 0 ; i < N ; i++ )
    {
   
    cout<<endl<<"      - Valor ["<<i + 1<<"] = "<<A[i]<<endl;
   
    }    
}

/****************************************************************************
el método de la sacudida (shaker sort).
Es la operación de arreglar los registros de una tabla en algún orden secuencial de acuerdo a cierto criterio de orden,
con el propósito principal de facilitar las búsqueda de los miembros del conjunto ordenado.
//****************************** SHAKER o sacudida**************************************/

int *Shaker(int *A, int N)
{
 int i = 0 , izq = 1 , der = N-1 , k = N-1 , aux = 0;
 while( der >= izq )
      {
      for( i = der ; i>= izq ; i-- )  
            if( A[i-1] > A[i])
              {
                aux = A[i-1];
                       
                A[i-1]=A[i];
                       
                A[i]=aux;
                       
                k=i;                    
              }            
      izq = k + 1;    
      for( i = izq ; i <= der ; i++)
             
            if( A[i-1] > A[i] )
                 
              {
                   
                aux = A[i-1];
                       
                A[i-1]=A[i];
                       
                A[i]=aux;
                       
                k=i;
              }
     
      der = k-1;

    }
 return A;
}

int main()
{
  system("COLOR F3");
   
  int *A = NULL;

  A = (int*)malloc(sizeof(int));

  int N;

  int opcion;
     
  cout<<endl<<"  >> INGRESE LOS VALORES :  ";
  cout<<endl<<"      --------------------------------> ";
  cin>>N;
 
  A = Insertar( A , N );
  A = Shaker( A , N );
               
                cout<<endl<<"  - [ METODO MEDIANTE SHAKER (SACUDIDA) ] - "<<endl;
               
                Mostrar(A , N);
    cout<<endl<<endl;
 system("pause");

}

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

Metodo Shell


codigo:

//metodo de Shell
#include<iostream>
#include <stdio.h>
#include <stdio.h>
#include <stdlib.h>
using namespace std;
//****************************** INSERTAR ************************************//

int *Insertar(int *A ,int N)
{
 for( int i = 0 ; i < N ; i++ )
    {
        cout<<endl<<"    - Ingrese el valor ["<<i + 1<<"] = ";
        cin>>A[i];
   
    }
 return A;  
}
//******************************* MOSTRAR ************************************//
void Mostrar(int *A ,int N)
{

 for( int i = 0 ; i < N ; i++ )
    {
   
    cout<<endl<<"      - Valor ["<<i + 1<<"] = "<<A[i]<<endl;
   
    }    
}

/****************************************************************************
El ordenamiento Shell (Shell sort en inglés) es un algoritmo de ordenamiento. El método se denomina Shell en honor de su inventor Donald Shell.
Su implementación original, requiere O(n2) comparaciones e intercambios en el peor caso. Un cambio menor presentado en el libro de V.
Pratt produce una implementación con un rendimiento de O(n log2 n) en el peor caso.
Esto es mejor que las O(n2) comparaciones requeridas por algoritmos simples pero peor que el óptimo O(n log n).
Aunque es fácil desarrollar un sentido intuitivo de cómo funciona este algoritmo, es muy difícil analizar su tiempo de ejecución.
//****************************** SHELL ***************************************/
int *Shell(int *A , int N)
{

 int i,j,bandera,aux;


 for( j = N/2 ; j > 0 ; j = j/2)
   
    {

    do
     {
   
        bandera=0;

       for( i = 0 ; i < N - j ; i++)
            {
           
          if( A[i] > A[i+j] )
            {
           
                aux = A[i];
             
                A[i] = A[i+j];
             
                A[i+j] = aux;
             
                bandera=1;
               
            }
     
            }
        }    
   
    while(bandera);

  }
 
 return A;
     
}

int main()
{
  system("COLOR F9");
   
  int *A = NULL;

  A = (int*)malloc(sizeof(int));

  int N;

  int opcion;
     
  cout<<endl<<"  >> INGRESE LOS VALORES :  ";
  cout<<endl<<"      --------------------------------> ";
  cin>>N;
 
  A = Insertar( A , N );
  A = Shell( A , N );
         cout<<endl<<"  - [ METODO MEDIANTE SHELL ] - "<<endl;
               
                Mostrar(A , N);
    cout<<endl<<endl;
 system("pause");

}

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

Metodo QuitShort


Codigo:

#include<iostream>
 #include <algorithm> //para la función sort
 #define LIM 50
 using namespace std;
 /****************************************************************************
El ordenamiento rápido (quicksort en inglés) es un algoritmo basado en la técnica de divide y vencerás, que permite, en promedio,
ordenar n elementos en un tiempo proporcional a n log n.
//****************************** Quitshort **************************************/

 void LeerArray(int n,int x[]);
 void MostrarArray(int n,int x[]);

 int main()
 {
  int n;
  int x[LIM];
  cout<<" -> Ingrese el numero de elementos :";cin>>n;
  LeerArray(n,x);
  sort(x,x+n);//sort(array,array+numeroelementos);
  cout<<"\t\t\t *** MEtodo Quic sort *** "<<endl<<endl;
  cout<<"\t";MostrarArray(n,x);
  system("pause>>null");
  return 0;
 }

 void MostrarArray(int n,int x[])
 {
     for(int i=0;i<n;i++)
     {
         cout<<x[i]<<" ";
     }
 }
 void LeerArray(int n,int x[])
 {
     for(int i=0;i<n;i++)
     {
         cout<<" Elemento ["<<i<<"]:";cin>>x[i];
     }
}

Deja tu comentario

Sean Bienvenidos a mi página.

- Copyright © Jason Igneel -