elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Tutorial básico de Quickjs


+  Foro de elhacker.net
|-+  Programación
| |-+  Programación C/C++ (Moderadores: Eternal Idol, Littlehorse, K-YreX)
| | |-+  [C++ Linux] Explicación de codigo [Principiante]
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: [1] 2 Ir Abajo Respuesta Imprimir
Autor Tema: [C++ Linux] Explicación de codigo [Principiante]  (Leído 6,013 veces)
EAX_

Desconectado Desconectado

Mensajes: 26


inside myself..


Ver Perfil
[C++ Linux] Explicación de codigo [Principiante]
« en: 28 Enero 2012, 16:56 pm »

Hola a todos,
               Les cuento. Este año voy a estudiar Ingeniería en informática y estoy repasando y practicando antes de entrar para llegar con algo y se me haga más fácil. Bueno, he estado estudiando este código que es bastante simple pero hay algunas cosas que aún me complican y quisiera pedirle que me expliquen. He buscado información y leído para responder muchas de mis preguntas pero hay unas que aún no logro responder.

Bueno acá va.

Código
  1. #include<cstdlib>
  2. #include<ctime>
  3. #include<iostream>
  4. #include<iomanip>
  5. using namespace std;
  6.  
  7. int f;
  8.  
  9. bool checkrep(int n, int num[])
  10. {
  11.    for(int i = 0; i < f; i++)
  12.        if(n == num[i])
  13.            return true;
  14.    return false;
  15. }
  16.  
  17. int main()
  18. {
  19.  
  20. cout << "f = ";
  21. cin >> f;
  22.  
  23.    srand(time(NULL));
  24.    int n, i, num[f];
  25.    for(i = 0; i < f; i++)
  26.    {
  27.       do  // porque este do acá?
  28.        n = 1 + rand() % 10;  //especificamente qué hace el simbolo % acá?
  29.        while(checkrep(n, num)); // tenia entendido que luego de while se abrian llaves, por qué acá no hay?
  30.  
  31.        num[i] = n;
  32.        cout << num[i] << " - ";
  33. }
  34.  
  35. float prom, sum = 0; // esto está bien? debe ser float?
  36. int k;
  37. int nmayor = num[0];
  38.  
  39. for(i = 0; i < f; i++) {
  40.  sum = sum + num[i];
  41.  if(nmayor < num[i]) {
  42.  nmayor = num[i];
  43. }
  44. }
  45. prom = sum/f;
  46.  
  47.        cout << endl << "El mayor de los numeros es: " << nmayor << endl;
  48.        cout << "La suma de los numeros es: " << sum << endl;
  49. cout << "El promedio de los numeros es: " << setprecision(3) << prom << endl;
  50.  
  51. }
  52.  

He dejado las notas en el mismo código para que las vean y entiendan. Espero obtener la ayuda que necesito.

Gracias de antemano.



EDITO:

Ese código es un mezcla de algunos ejercicios de elhacker.net y modificaciones mías. Funciona, pero quiero saber la forma correcta de programarlo.

Estoy compilando con g++ en Debian Squeeze.


« Última modificación: 28 Enero 2012, 17:03 pm por EAX_ » En línea

"Everyone is a genius. But if you judge a fish on its ability to climb a tree, it will live its whole life believing it is stupid." - Albert Einstein
DickGumshoe


Desconectado Desconectado

Mensajes: 480



Ver Perfil WWW
Re: [C++ Linux] Explicación de codigo [Principiante]
« Respuesta #1 en: 28 Enero 2012, 17:15 pm »

Cito la parte donde tienes problemas:

Código
  1. srand(time(NULL));
  2.    int n, i, num[f];
  3.    for(i = 0; i < f; i++)
  4.    {
  5.       do  // porque este do acá?
  6.        n = 1 + rand() % 10;  //especificamente qué hace el simbolo % acá?
  7.        while(checkrep(n, num)); // tenia entendido que luego de while se abrian llaves, por qué acá no hay?

Ese do va con el while de debajo (es un bucle do-while). Entonces, hace
 n = 1 + rand() % 10;

mientras (checkrep(n, num));

El % va ahí porque forma parte de la función rand en ese caso. Si pusieras
n=rand(), te calcularía cualquier número aleatoriamente. Poniendo detrás de rand() un signo de % y posteriormente un número, el ordenador piensa un número  desde el 0 hasta el número que has introducido.

En el while no van las llaves, porque, como dije antes, es un bucle do-while. Si fuera un bucle while, sí sería con llaves (Ojo, que el bucle do-while también puede llevar llaves, pero en este caso, como no tiene que ejecutar muchas sentencias, no hacen falta).

Espero haberte ayudado.

Saludos.



« Última modificación: 28 Enero 2012, 17:22 pm por DickGumshoe » En línea

satu


Desconectado Desconectado

Mensajes: 301

Siempre aprendiendo


Ver Perfil WWW
Re: [C++ Linux] Explicación de codigo [Principiante]
« Respuesta #2 en: 28 Enero 2012, 18:09 pm »

Hola

El % va ahí porque forma parte de la función rand en ese caso. Si pusieras
n=rand(), te calcularía cualquier número aleatoriamente. Poniendo detrás de rand() un signo de % y posteriormente un número, el ordenador piensa un número  desde el 0 hasta el número que has introducido.

En realidad el signo % es un operador y se llama "módulo". Igual que + se utiliza para sumar y - para restar, el operador % calcula el resto de una división entera. Por ejemplo:

10 % 2 es igual a 0, porque 10 / 2 = 5 y resto 0
10 % 3 es igual a 1, porque 10 / 3 = 3 y resto 1

Código
  1. n = 1 + rand() % 10;
  2.  
lo que hace es buscar un número aleatorio (rand), lo divide entre 10 y se queda con el resto (que será un número entre 0 y 9) y a ese resto le suma 1 y guarda ese valor en la variable n, con lo que n valdrá entre 1 y 10.

Si por ejemplo rand() devuelve 53, n será 4, ya que 53 % 10 es 3, le sumamos 1 y n vale 4.

Lo has entendido??

Si tienes más dudas pregunta sin problema.

Saludos
En línea

Breakbeat como forma de vida
DickGumshoe


Desconectado Desconectado

Mensajes: 480



Ver Perfil WWW
Re: [C++ Linux] Explicación de codigo [Principiante]
« Respuesta #3 en: 28 Enero 2012, 18:11 pm »

Ah, satu, si está mal lo que dije creo que voy a cambiar de manual. En el que estoy usando viene así, y, sin embargo, me acabo de fijar que en otros viene igual que como lo has dicho...
En línea

satu


Desconectado Desconectado

Mensajes: 301

Siempre aprendiendo


Ver Perfil WWW
Re: [C++ Linux] Explicación de codigo [Principiante]
« Respuesta #4 en: 28 Enero 2012, 18:22 pm »

Hola

No está mal como lo has dicho, solo que yo le he explicado la función de % independientemente de si se usa con rand() o no. En este caso, como va con rand() hace lo que tú has dicho pero su uso (general) es el que le he dicho yo.

Saludos
En línea

Breakbeat como forma de vida
DickGumshoe


Desconectado Desconectado

Mensajes: 480



Ver Perfil WWW
Re: [C++ Linux] Explicación de codigo [Principiante]
« Respuesta #5 en: 28 Enero 2012, 18:24 pm »

Ah, vale, gracias. Ya me había asustado y creía que estaba leyendo un manual malo.

Saludos.
En línea

Xandrete

Desconectado Desconectado

Mensajes: 210



Ver Perfil
Re: [C++ Linux] Explicación de codigo [Principiante]
« Respuesta #6 en: 28 Enero 2012, 18:40 pm »

Estoy viendo otra cosa muy horrorosa...

Código
  1. int n, i, num[f] // es la parte de int num[f] la que esta mal

No, no y no. Tal vez el compilador no se haya quejado, pero eso no quiere decir que sea correcto (rotundamente, NO lo es). ¿Por qué? Porque un array se ha de inicializar con un tamaño no decidido en tiempo de ejecución (el compilador tiene que saber el tamaño). ¿La forma correcta de hacerlo? Reservando memoria dinámica.

Código
  1. int* num = new int[f];

O, alternativamente:

Código
  1. int* num = malloc(f); // hay que incluir cstdlib primero

Por otro lado... ¡estás en C++! ¡Aquí tienes vectores! Tienes esta otra opción:

Código
  1. vector<int> num(f); // hay que incluir vector primero

Respecto a la pregunta "¿Debe ser float?", que nadie te ha contestado aun.

¿Debe? Hombre, deber, deber... ¿Poder? Claro, puedes usar float. O int, o char, o double. Depende de tus necesidades. ¿Quieres precisión decimal normalita? Usa float. ¿Sólo te interesa la parte entera de la división? Usa int. ¿Gran precisión decimal? Usa double. Como he dicho. no debe ser ni una cosa ni otra. Depende de qué es lo que te hace falta.

Saludos

P.S. Por curiosidad, ¿a qué universidad piensas ir :-) ?
« Última modificación: 28 Enero 2012, 18:45 pm por Xandrete » En línea

satu


Desconectado Desconectado

Mensajes: 301

Siempre aprendiendo


Ver Perfil WWW
Re: [C++ Linux] Explicación de codigo [Principiante]
« Respuesta #7 en: 28 Enero 2012, 18:44 pm »

No me había fijado en eso, muchas gracias Xandrete por decirlo, se me pasó.

Saludos
En línea

Breakbeat como forma de vida
EAX_

Desconectado Desconectado

Mensajes: 26


inside myself..


Ver Perfil
Re: [C++ Linux] Explicación de codigo [Principiante]
« Respuesta #8 en: 28 Enero 2012, 18:50 pm »

Antes que algo, gracias a todos por responder.

Cito:

10 % 2 es igual a 0, porque 10 / 2 = 5 y resto 0
10 % 3 es igual a 1, porque 10 / 3 = 3 y resto 1

No logro entender eso.

10 / 2 = 5... y ¿Resto 0? Eso es lo que no comprendo.

Encontré algo parecido por acá:

Código
  1. #include <stdio.h>
  2. #include <conio.h>
  3. #include <iostream.h>
  4. int main ()
  5. {
  6.    clrscr();
  7.    for (int i=1;i<=20;i++)
  8.    {
  9. cout<<i;
  10. if (i%3==0) cout<<" Es multiplo de 3" <<endl;
  11. else cout<<" No es multiplo de 3"<<endl;
  12.    }
  13.    getch();
  14.    return 0;
  15. }

No entiendo por qué i % 3 es igual a 0 o a 1. Si pudieras explicarlo con manzanas te lo agradecería... estoy confundido.

Saludos y gracias de antemano.

PD:

Xandrete, gracias por la aclaración. Aunque el compilador nunca se quejó de eso, voy a tener cuidado con lo que me dices. Y supongo que puedo prescindir de la palabra new al crear el array ¿O no?

En cuanto a donde estudiaré... pretendo estudiar en un instituto y luego saltar a la universidad, desde AIEP a Universidad Andres Bello.
En línea

"Everyone is a genius. But if you judge a fish on its ability to climb a tree, it will live its whole life believing it is stupid." - Albert Einstein
DickGumshoe


Desconectado Desconectado

Mensajes: 480



Ver Perfil WWW
Re: [C++ Linux] Explicación de codigo [Principiante]
« Respuesta #9 en: 28 Enero 2012, 18:59 pm »

En el ejemplo que acabas de poner, si el resto de dividir i entre 3 es 0, imprimes por pantalla que es múltiplo de 3, y, sino, dirá que no lo es.

Por si acaso no has caído en este momento, con el resto se refiere a la forma en la que hacemos las divisiones normalmente sin calculadora y sin usar decimales.

Por ejemplo: 6:3 (diríamos que 3x2 es 6, por lo que, al ser exacto, el resto es 0) --> Imprime por pantalla que es múltiplo de 3.
7:3 (si cogemos 3x3, que es igual a 9, se pasa de 7. Entonces cogemos el 2. 3x2=6. Del 6 al 7, 1. El resto es 1) --> Imprime por pantalla que no es múltiplo de 3.

Saludos.
En línea

Páginas: [1] 2 Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
Ayuda, explicacion de codigo
Programación C/C++
negux 1 2,877 Último mensaje 28 Abril 2010, 08:12 am
por Akai
ayuda con explicacion de codigo
Programación C/C++
Fatmf44 1 2,614 Último mensaje 24 Junio 2010, 00:10 am
por Littlehorse
explicacion de codigo
Programación C/C++
flony 3 2,950 Último mensaje 12 Octubre 2010, 14:06 pm
por flony
Ayuda no entiendo esta parte del codigo, soy principiante
Programación C/C++
spiderboot 3 3,322 Último mensaje 30 Enero 2014, 18:14 pm
por spiderboot
Explicación de un codigo
Programación C/C++
Nabore 2 2,113 Último mensaje 8 Mayo 2016, 06:38 am
por Nabore
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines