我必须编写一个递归函数asterisk_triangle,它接受一个整数,然后返回一个由许多行组成的星号三角形.
例如,这是一个4行星号三角形.
*
**
***
****
Run Code Online (Sandbox Code Playgroud)
我想出了这个功能:
def asterisk_triangle(n):
"""
takes an integer n and then returns an
asterisk triangle consisting of (n) many lines
"""
x = 1
while (x <= n):
print("*" * x)
x = x + 1
return
Run Code Online (Sandbox Code Playgroud)
而且我还必须通过操纵第一个函数来创建一个颠倒的星号三角形.
我想出了这个功能和结果:
def upside_down_asterisk_triangle(n):
"""
takes an integer n and then returns a backwards
asterisk triangle consisting of (n) many lines
"""
x = 0
while (x < n):
print("*" * (n-x))
x = x + 1
return
****
***
**
*
Run Code Online (Sandbox Code Playgroud)
现在我必须操纵这些函数来创建一个向后的星号三角形.
*
**
***
****
Run Code Online (Sandbox Code Playgroud)
并且一个向后颠倒的星号三角形.
****
***
**
*
Run Code Online (Sandbox Code Playgroud)
我应该实现哪些功能?
我已尝试在函数后使用反向字符串命令[:: - 1],但它不起作用.
我早些时候已经回答了同样的问题.请记住,您提到的所有recursive功能都不是功能.您可以在此处阅读有关递归的更多信息.
这是我在这里提到的例子.
Python 3.X
def asterix_triangle(i, t=0):
if i == 0:
return 0
else:
print(' ' * ( i + 1 ) + '*' * ( t * 2 + 1 ))
return asterix_triangle( i - 1, t + 1 )
asterix_triangle(5)
Run Code Online (Sandbox Code Playgroud)
在这里,您有一个递归函数的颠倒版本.
def upside_down_asterix_triangle(i, t=0):
if i == 0:
return 0
else:
print(' ' * ( t + 1 ) + '*' * ( i * 2 - 1 ))
return upside_down_asterix_triangle( i - 1, t + 1 )
upside_down_asterix_triangle(5)
Run Code Online (Sandbox Code Playgroud)
Python 2.X
def asterix_triangle(i, t=0):
if i == 0:
return 0
else:
print ' ' * ( i + 1 ) + '*' * ( t * 2 + 1 )
return asterix_triangle( i - 1, t + 1 )
asterix_triangle(5)
Run Code Online (Sandbox Code Playgroud)
在这里,您有一个递归函数的颠倒版本.
def upside_down_asterix_triangle(i, t=0):
if i == 0:
return 0
else:
print ' ' * ( t + 1 ) + '*' * ( i * 2 - 1 )
return upside_down_asterix_triangle( i - 1, t + 1 )
upside_down_asterix_triangle(5)
Run Code Online (Sandbox Code Playgroud)
编辑: 显示在IDE中运行的脚本的屏幕截图.

Edit2: 添加了在Python 3.x下运行的代码
Edit3: 为Python 3.X添加了迭代功能
def create_pyramid(rows):
for i in range(rows):
print((' ' * ( rows- i - 1 ) + '*' * ( 2 * i + 1)))
print((create_pyramid(5)))
def create_upside_down_pyramid(rows):
for i in reversed(list(range(rows))):
print((' ' * ( rows- i - 1 ) + '*' * ( 2 * i + 1)))
print((create_upside_down_pyramid(5)))
Run Code Online (Sandbox Code Playgroud)