Foro de elhacker.net

Programación => Programación C/C++ => Mensaje iniciado por: tokyo13 en 27 Febrero 2019, 14:54 pm



Título: Programa para calcular numeros perfectos entre 1 y N
Publicado por: tokyo13 en 27 Febrero 2019, 14:54 pm
De momento llevo esto, el programa compila y ejecuta pero el resultado obtenido no es el correcto y no encuentro el error. Soy principiante en programación  ;D

Código:
#include <iostream>
using namespace std;

bool esPerfecte(int num)
{
int div;
int suma = 0;

for (div = 1; div <= num; div++)
{
if (num%div == 0)
{
suma = suma + div;

}
}

if (suma == num)
{

return true;
}
else
{

return false;
}

}

int main()
{
int n;
cout << "Introduce un numero" << endl;
cin >> n;
cout << "Los num perfectos son: " << endl;

for (int i = 1; i <= n; i++)
{
esPerfecte(i);

if (esPerfecte(i) == true)
{
cout << i << endl;
}


}

system("PAUSE");
}

Gracias :)


Título: Re: Programa para calcular numeros perfectos entre 1 y N
Publicado por: CalgaryCorpus en 27 Febrero 2019, 16:37 pm
y si reemplazas, en esPerfecte, el <= por un < ?


Título: Re: Programa para calcular numeros perfectos entre 1 y N
Publicado por: K-YreX en 27 Febrero 2019, 20:32 pm
Como te ha comentado CalgaryCorpus el error está en el signo <= que debería ser sólo < ya que sino lo que ocurre es que el propio número como es divisible consigo mismo se suma su valor a la suma y entonces nunca coincide.

Solucionado el problema te dejo un ćodigo correspondiente a tu misma función pero un poco más estética:
Código
  1. bool isPerfect(size_t number){
  2. size_t sum = 0;
  3. for(size_t divisor = 1; divisor < number; divisor++)
  4. if(number % divisor == 0)
  5. sum += divisor;
  6. return (sum == number);
  7. }

Y el programa principal también se puede mejorar un poco ya que en cada iteración estás llamando a la función dos veces seguidas de las cuales la primera no sirve ya que el valor de retorno se está perdiendo. En vez de usar <system("pause") es mejor que uses <cin.get()>.
Código
  1. int main(){
  2. int limit;
  3. cout << "Introduce el limite superior: ";
  4. cin >> limit;
  5.  
  6. for(size_t number = 1; number <= limit; number++)
  7. if(isPerfect(number))
  8. cout << number << endl;
  9.        cin.get();
  10. }


Título: Re: Programa para calcular numeros perfectos entre 1 y N
Publicado por: tokyo13 en 27 Febrero 2019, 22:38 pm
Muchísimas gracias por responder! Ya está solucionado. Parece mentira como un error tan simple te lo manda todo a tomar viento.