Python - Piramide numérica

 
Vista:
sin imagen de perfil

Piramide numérica

Publicado por Jonatan (7 intervenciones) el 10/07/2013 23:58:27
Que tal soy nuevo por aqui, me gustaría saber si alguien puede ayudarme con éste algoritmo que no he podido resolver desde ya gracias por su gran aporte!
"diseñar un algoritmo que imprima ésta piramide":

55555
4444
333
22
1

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
def triangulo(n):
    for f in range (1,n+1):
        acum=""
        for c in range (1,f+1):
            acum = acum +str(f)
        print (acum)
 
def main():
    num = input ("ingrese cant. de lineas")
    if (num>=1 and num<=9):
        triangulo(num)
    else:
        print ("error")
 
>>> main()
ingrese cant. de lineas5
1
22
333
4444
55555
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder
Imágen de perfil de xve
Val: 2.239
Plata
Ha mantenido su posición en Python (en relación al último mes)
Gráfica de Python

Piramide numérica

Publicado por xve (1646 intervenciones) el 11/07/2013 07:14:41
Hola Jonatan, tienes el código bien, lo unico que tienes que hacer es invertir el orden...

En vez de utilizar esta linea:
1
for f in range (1,n+1):

prueba con:
1
for f in range(n,0,-1):


Coméntanos, ok?
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
1
Comentar
sin imagen de perfil

Piramide numérica

Publicado por Jonatan Leopoldo (7 intervenciones) el 11/07/2013 15:56:24
Muchas gracias funciono, ahora voy a realizar la traza para comprenderlo mejor
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

Piramide numérica

Publicado por felipe mendez (1 intervención) el 12/09/2013 10:16:30
amigo yo eh hecho algo parecido espero te sirva, utilice codigos mas sencillos;

# -*- coding: cp1252 -*-
# Autor: Felipe mendez
# Fecha: Martes 7/4/2013
#
#
# Definición de funciones
# Definición de funciones propias
def dibujaTriangulos(n):

# Sea i las filas
i = 1

j = 1

while i < n :

# Sea j las columnas

while j <= n :

# Sea c un contador
c = 0
if j% 2 == 0:
while j <= n :

j = j + 1
c = c + 1
print "1",

j = j - c + 1
print " "

else :
while j <= n :

j = j + 1
c = c + 1
print "0",
print " "
j = j - c + 1
i = i + 1


# BLOQUE PRINCIPAL

# ENTRADA

n = input("Ingrese hasta donde iterar: ")

# PROCESAMINETO
dibujaTriangulos(n)


ejemplo al runear el programa:

Ingrese hasta donde iterar: 8
0 0 0 0 0 0 0 0
1 1 1 1 1 1 1
0 0 0 0 0 0
1 1 1 1 1
0 0 0 0
1 1 1
0 0
1
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
1
Comentar