Buenas, soy nueva programando en C. Estoy intentando crear un programa que tenga un array de 100 numeros aleatorios entre 1 y 1000. Una vez creado quiero organizarlo de tal manera que almacene los numeros pares en un array y los impares en otro.
Creo que el problema está en la función aleatoria de la librería time.h que estoy empleando, dado que no genera números diferentes para cada componente del vector. Cada vez que ejecuto el programa crea un número distinto que se copia en todas las componentes. Sin embargo, está dentro de un bucle for, luego no llego a entender cuál es el problema. Adjunto mi código a continuación. Gracias por su tiempo:
#include<stdio.h>
#include<conio.h>
#include<time.h>
#include<stdlib.h>
#define MAX 100
int rellena_vector (int v[] );
void search_even (int v[MAX], int p[MAX], int cont_pares);
void search_odd (int v[MAX], int im[MAX], int cont_imp);
int main(){
int v[100], p[MAX], im[MAX];
int cont_pares;
int cont_imp;
int i;
cont_pares=rellena_vector (v);
search_even (v, p, cont_pares);
cont_imp=MAX-cont_pares;
search_odd (v,im, cont_imp);
return 0;
}
int rellena_vector (int v[] ){
int r=0, i, cont_pares=0;
for (i=0;i<100; i++)
{
r
=1+rand() % ((1000 +1)-1);v[i]=r;
if (v[i]%2==0)
{cont_pares++;
}
}
return cont_pares;
}
void search_even (int v[MAX], int p[MAX], int cont_pares)
{
int i, k=0;
for (i=0;i<MAX;i++){
if (v[i]%2==0)
{
p[k]=v[i];
k++;
}
}
printf("\nA continuacion el vector de pares:" );
for (k=0;k<cont_pares;k++)
{
}
}
void search_odd (int v[MAX], int im[MAX], int cont_imp)
{
int i, k=0;
for (i=0;i<MAX;i++){
if (v[i]%2==1)
{
im[k]=v[i];
k++;
}
}
printf("\nA continuacion el vector de impares:" );
for (k=0;k<cont_imp;k++)
{
}
}
Engel Lex: Los códigos deben usar etiquetas GeSHi
Te propongo que cambies el planteamiento.
1º Genera el array de nº aleatorios:
Entero: k, Array(de 100 elementos)
Bucle K de 0 a 99
Array(k) = Random(1-1000)
Fin bucle
2º Derivar los impares abajo en el array, los pares arriba en el array
Entero: Impares, pares, tmp
Impares=0
Pares=99
Mientras Pares sea mayor que Impares
Mientras ((Array(Impares) and 1) = 1) //recorriendo desde abajo, si es impar saltamos al siguiente
Impares += 1
Repetir
Mientras ((Array(Pares) and 1) = 0) // desde arriba hacia abajo, si es par saltamos al anterior
Pares -= 1
Repetir
// Tenemos un par abajo y un impar arriba, intercambiarlos.
tmp = Array(impares)
Array(impares) = Array(Pares)
Array(Pares) = Tmp
Repetir
// La condición del bucle principal, hace que el punto de encuentro se hayan intercambiado, luego los corregimos (tratar de añadir condicionales para evitarlo, supone código más ineficiente que estas tres líneas para arreglarlo):
tmp = Array(impares)
Array(impares) = Array(Pares)
Array(Pares) = Tmp
Es un código sencillo, escueto... y resuelve bien el problema en pocas líneas de código.