0votos

Factorion en Java

por alvaro sanz llorente hace 4 días

Asi lo he hecho

Sabiendo que no hay factoriones mayores que 2.500.000, encontrarlos a todos.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
public class Factorion { 
 
    public boolean esfactorion(int h) { 
        boolean esfactorion = false; 
        int numero1 = 0; 
        int numero2 = 0; 
        int multiplicacion = 1; 
        int suma = 0; 
        String numero = String.valueOf(h); 
        for (int f = 0; f < numero.length(); f++) { 
 
            numero1 = Integer.parseInt("" + numero.charAt(f)); 
 
            for (int c = 1; c <= numero1; c++) { 
                multiplicacion *= c; 
 
 
            suma += multiplicacion; 
            multiplicacion = 1; 
 
 
        numero2 = Integer.parseInt(numero); 
 
        if (numero2 == suma) { 
            esfactorion = true; 
        return esfactorion; 
 
    public static void main(String[] args) { 
 
        Factorion fa = new Factorion(); 
 
        for (int h = 0; h < 2500000; h++) { 
            if (fa.esfactorion(h) == true) { 
                System.out.println(h); 
 
 

Comenta la solución

Tienes que identificarte para poder publicar tu comentario.