Este programa coloca valores dentro de un arreglo, ordena los valores en orden ascendente, e imprime los resultados del arreglo.
c:
#include <stdio.h>
#define TAMANIO 10
void ordenamBurbuja( int * const arreglo, const int tamanio ); /* prototipo */
int main()
{
/* inicializa el arreglo a */
int a[ TAMANIO ] = { 2, 6, 4, 8, 10, 12, 89, 68, 45, 37 };
int i; /* contador */
printf( "Elementos de datos en el orden original\n" );
/* ciclo a través del arreglo a */
for ( i = 0; i < TAMANIO; i++ ) {
printf( "%4d", a[ i ] );
} /* fin de for */
ordenamBurbuja( a, TAMANIO ); /* ordena el arreglo */
printf( "\nElementos de datos en orden ascendente\n" );
/* ciclo a través del arreglo a */
for ( i = 0; i < TAMANIO; i++ ) {
printf( "%4d", a[ i ] );
} /* fin de for */
printf( "\n" );
return 0; /* indica terminación exitosa */
} /* fin de main */
/* ordena un arreglo de enteros mediante el uso del algoritmo de la burbuja */
void ordenamBurbuja( int * const arreglo, const int tamanio )
{
void intercambia( int *ptrElemento1, int *ptrElemento2 ); /* prototipo */
int pasada; /* contador de pasadas */
int j; /* contador de comparaciones */
/* ciclo para controlar las pasadas */
for ( pasada = 0; pasada < tamanio - 1; pasada++ ) {
/* ciclo para controla las comparaciones durante cada pasada */
for ( j = 0; j < tamanio - 1; j++ ) {
/* intercambia los elementos adyacentes si no están en orden */
if ( arreglo[ j ] > arreglo[ j + 1 ] ) {
intercambia( 038;arreglo[ j ], 038;arreglo[ j + 1 ] );
} /* fin de if */
} /* fin del for interno */
} /* fin del for externo */
} /* fin de la función ordenamBurbuja */
/* intercambia los valores en las ubicaciones de memoria a los cuales apunta ptrElemento1 y
ptrElemento2 */
void intercambia( int *ptrElemento1, int *ptrElemento2 )
{
int almacena = *ptrElemento1;
*ptrElemento1 = *ptrElemento2;
*ptrElemento2 = almacena;
} /* fin de la función intercambia */
#define TAMANIO 10
void ordenamBurbuja( int * const arreglo, const int tamanio ); /* prototipo */
int main()
{
/* inicializa el arreglo a */
int a[ TAMANIO ] = { 2, 6, 4, 8, 10, 12, 89, 68, 45, 37 };
int i; /* contador */
printf( "Elementos de datos en el orden original\n" );
/* ciclo a través del arreglo a */
for ( i = 0; i < TAMANIO; i++ ) {
printf( "%4d", a[ i ] );
} /* fin de for */
ordenamBurbuja( a, TAMANIO ); /* ordena el arreglo */
printf( "\nElementos de datos en orden ascendente\n" );
/* ciclo a través del arreglo a */
for ( i = 0; i < TAMANIO; i++ ) {
printf( "%4d", a[ i ] );
} /* fin de for */
printf( "\n" );
return 0; /* indica terminación exitosa */
} /* fin de main */
/* ordena un arreglo de enteros mediante el uso del algoritmo de la burbuja */
void ordenamBurbuja( int * const arreglo, const int tamanio )
{
void intercambia( int *ptrElemento1, int *ptrElemento2 ); /* prototipo */
int pasada; /* contador de pasadas */
int j; /* contador de comparaciones */
/* ciclo para controlar las pasadas */
for ( pasada = 0; pasada < tamanio - 1; pasada++ ) {
/* ciclo para controla las comparaciones durante cada pasada */
for ( j = 0; j < tamanio - 1; j++ ) {
/* intercambia los elementos adyacentes si no están en orden */
if ( arreglo[ j ] > arreglo[ j + 1 ] ) {
intercambia( 038;arreglo[ j ], 038;arreglo[ j + 1 ] );
} /* fin de if */
} /* fin del for interno */
} /* fin del for externo */
} /* fin de la función ordenamBurbuja */
/* intercambia los valores en las ubicaciones de memoria a los cuales apunta ptrElemento1 y
ptrElemento2 */
void intercambia( int *ptrElemento1, int *ptrElemento2 )
{
int almacena = *ptrElemento1;
*ptrElemento1 = *ptrElemento2;
*ptrElemento2 = almacena;
} /* fin de la función intercambia */