función random

Iniciado por m@o_614, 5 Noviembre 2012, 19:35 PM

0 Miembros y 3 Visitantes están viendo este tema.

m@o_614

Saludos

Tengo una duda con respecto a la función random

Si quisiera generar numeros aleatorios del 0 al 10 por ejemplo, sería algo como
rand()%11; pero que pasa cuando de esos números del 0 al 10 no quiero que se generen el 6 y el 4, por ejemplo.

¿Cómo podría hacer una excepción de algunos números?

de antemano gracias

Stakewinner00

puedes poner algo como
Código (cpp) [Seleccionar]
if ((x==4)||(x==6)) {
} else {
}


y de ese modo puedes excluir de tu código el 6 y el 4

m@o_614

Mi código es el siguiente, lo que me pide es generar cinco operaciones con los signos (+,-,*,/) aleatoriamente, para eso estoy utilizando los números ASCII:

42 = *
43 = +
44 = ,
45 = -
46 = .
47 = /

el único problema son el 44 y el 46

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define OPERACIONES 5

int main()
{
    int i,numero1,numero2,resultado;
    char operacion;
    srand(time(NULL));
    for(i=0;i<OPERACIONES;i++)
    {
        numero1 = rand()%11;
        numero2 = rand()%11;
        operacion = rand()% 6+42;
        if((operacion==44)||(operacion==46))
        printf("%d %c %d = ",numero1,operacion,numero2);
        scanf("%d",&resultado);
    }
    return 0;
}

leosansan

CitarTal como tienes planteado el if sólo sería cierto en los dos casos en que debe ser falso. Además hay que tener en cuenta si el aleatorio genera un valor no válido, lo que está contemplado en el "else" y para que lo veas he puesto "OTRO", que puedes quitar una vez entiendas como funciona:
Código (cpp) [Seleccionar]
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define OPERACIONES 5

int main()
{
    int i,numero1,numero2,resultado;
    char operacion;
    srand(time(0));
    for(i=0;i<OPERACIONES;i++)
    {
        numero1 = rand()%11;
        numero2 = rand()%11;
        operacion = rand()% 6+42;

        if(operacion==42 || operacion==43  || operacion==45 || operacion==47)
            {
                printf("%d %c %d = ",numero1,operacion,numero2);
                scanf("%d",&resultado);
            }
        else
            {
                i--;puts ("Otro");continue;
            }
    }
    return 0;
}

Saludos!.

m@o_614

Saludos leosansan

una última pregunta en el else de tu código pusiste i-- ¿por qué? no entiendo para qué pusiste ese contador

gracias por tu ayuda

leosansan

#5
Cita de: m@o_614 en  6 Noviembre 2012, 00:45 AM
una última pregunta en el else de tu código pusiste i-- ¿por qué? no entiendo para qué pusiste ese contador
CitarSi resulta un valor no válido -si entra en el else- habrá que descontarlo, de ahí el i--, si no tendrías menos de cinco valores, ya que se contarían también los valores no válidos
Saludos!.

rir3760

Cita de: leosansan en  6 Noviembre 2012, 16:23 PMSi resulta un valor no válido -si entra en el else- habrá que descontarlo, de ahí el i--, si no tendrías menos de cinco valores, ya que se contarían también los valores no válidos
En tu programa el uso de la sentencia "continue;" no es necesario ya que, si revisas con cuidado, es la ultima sentencia del bucle.

Y los dos cambios al contador se pueden reducir a uno si se utiliza un bucle "while" o "do ... while", por ejemplo:
i = 0;
do {
   numero1 = rand() % 11;
   numero2 = rand() % 11;
   operacion = rand() % 6 + 42;
   
   if (operacion == 44 || operacion == 46)
      puts("Otro");
   else {
      printf("%d %c %d = ", numero1, operacion, numero2);
      scanf("%d", &resultado);
      i++;
   }
}while (i < OPERACIONES);


El problema de fondo (ignorar valores no deseados) se puede evitar simplemente almacenando los operadores en un array, la función "rand" se utiliza para generar el indice del operador a utilizar:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define OPERACIONES 5

int main()
{
   char opers[] = {'+', '-', '*', '/'};
   size_t num_opers = sizeof opers;
   size_t i;
   int a;
   int b;
   int resultado;
   char operacion;
   
   srand((unsigned) time(NULL));
   
   for (i = 0; i < OPERACIONES; i++){
      a = rand() % 11;
      b = rand() % 11;
      operacion = opers[rand() % num_opers];
     
      printf("%d %c %d = ", a, operacion, b);
      scanf("%d", &resultado);
   }
   
   return 0;
}


Un saludo
C retains the basic philosophy that programmers know what they are doing; it only requires that they state their intentions explicitly.
--
Kernighan & Ritchie, The C programming language

leosansan

Cita de: rir3760 en  6 Noviembre 2012, 17:49 PMEn tu programa el uso de la sentencia "continue;" no es necesario ya que, si revisas con cuidado, es la ultima sentencia del bucle.
Pardillo, que soy un pardillo.....

CitarY los dos cambios al contador se pueden reducir a uno si se utiliza un bucle "while" o "do ... while"
Eso ya es lo clásico de un for o un while o do while, pero se agradece la observación.

Citar
   size_t num_opers = sizeof opers;
   size_t i;

Me asalta la duda, tonta supongo: ¿por qué usar size_t en lugar de int?.
Saludos!.

BatchianoISpyxolo

Pues aquí un código para generar un vector de números aleatorios en un rango:

#include <stdio.h>
#include <math.h>
#include <sys/time.h>
#define TAM 10

void inicializar_semilla() {
srand(time(NULL));
}

/* genera un vector de tamaño n con números de -10 a 10 */
void aleatorio_mod10(int v[], int n) {
int i;
inicializar_semilla();
for (i=0; i < n; i++)
v[i] = (rand() % 21) - 10;
}

int main () {
    int vector[TAM], i;
    aleatorio_mod10(vector, TAM);
    for (i=0; i<TAM; i++)
printf("%d ", vector[i]);
    printf("\n");
}


rand() % x: genera un número aleatorio entre 0 y x-1

En mi caso: rand() % 21: genera números entre 0 y 20.

Si a ese resultado le resto 10, pues genero números en el rango [-10,10] en Z
Puede que desees aprender a programar desde 0: www.espascal.es

rir3760

Cita de: leosansan en  6 Noviembre 2012, 20:18 PM¿por qué usar size_t en lugar de int?
Primero porque ese es el tipo de la expresión "sizeof opers" y segundo porque algunos compiladores, al utilizarse en su modo mas estricto, se quejan de operaciones entre tipos con signo (el tipo "int") y sin el (el tipo "size_t").

Un saludo
C retains the basic philosophy that programmers know what they are doing; it only requires that they state their intentions explicitly.
--
Kernighan & Ritchie, The C programming language