Código de Python - Descomposición en factores primos

Imágen de perfil

Descomposición en factores primosgráfica de visualizaciones


Python

Publicado el 27 de Mayo del 2020 por Administrador (718 códigos)
10.243 visualizaciones desde el 27 de Mayo del 2020
Un número primo es un número p>=2p>=2 que tiene únicamente como divisores positivos a 11 y a pp. Los números mayores o iguales a dos que no son primos, son denominados de números compuestos.

Según la teoría de números, un número compuesto se describir como el producto de dos o más números primos. Estos números primos se denominan factores primos y el proceso de encontrar los factores primos de un número se denomina factorización.

Dado un número natural mayor o igual a dos se pide:
- Representar el número como un producto de sus factores primos.
- Representar el número como un producto de sus factores primos pero en caso que se repita un factor primo, deberá indicarse el exponente de este.

1
2
Ingrese un número (>1): 3960
2^3x3^2x5x11

20200502

Publicado el 27 de Mayo del 2020gráfica de visualizaciones de la versión: 20200502
10.244 visualizaciones desde el 27 de Mayo del 2020
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella


Forma parte de Descomposición en factores primos
 
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#Creado por Andrés Melgar
#para iterando++ http://iterando.online/
#entrada: http://iterando.online/ejercicios-resueltos/descomposicion-en-factores-primos-en-python/
import math
 
def es_primo(n):
    if n <= 0:
        return False
    cant_divisores = 0
    encontro_divisores = False
    limite=math.sqrt(n)
    i = 2
    while i <= limite and not encontro_divisores:
        if n % i == 0:
            cant_divisores+=1
            encontro_divisores = True
        i+=1
    if cant_divisores==0 and n>1:
        return True
    return False
 
def siguiente_primo(n):
    while True:
        n+=1
        if es_primo(n):
            return n
 
def escribe_factor(hay_factores, factor_primo, cant_factores):
    if cant_factores > 0:
        if hay_factores:
            print("x", end="")
        else:
            hay_factores = True
        if cant_factores==1:
            print(factor_primo, end="")
        else:
            print("{:d}^{:d}".format(factor_primo, cant_factores), end="")
        cant_factores = 0
        return hay_factores, cant_factores
 
def descomponer_factores(n):
    productoria = 1
    copia_n = n
    factor_primo = 2
    cant_factores = 0
    hay_factores = False
    while True:
        resto = copia_n % factor_primo
        if resto == 0:
            copia_n //= factor_primo
            productoria *= factor_primo
            cant_factores += 1
        else:
            if cant_factores > 0:
                hay_factores, cant_factores = escribe_factor(hay_factores, factor_primo, cant_factores)
            factor_primo = siguiente_primo(factor_primo)
 
        if productoria == n:
            break;
    escribe_factor(hay_factores, factor_primo, cant_factores)
 
n=int(input("Ingrese un número (>1): "))
if n <= 1:
    print("Debe ingresar un número mayor que uno")
else:
    descomponer_factores(n)



Comentarios sobre la versión: 20200502 (0)


No hay comentarios
 

Comentar la versión: 20200502

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s6232