【问题标题】:Asterisk triangle in python [duplicate]python中的星号三角形[重复]
【发布时间】:2013-03-22 00:37:08
【问题描述】:

我必须编写一个递归函数 asterisk_triangle,它接受一个整数,然后返回一个由那么多行组成的星号三角形。

例如,这是一个 4 行星号三角形。

*
**
***
****

我想出了这个功能:

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

而且我还必须通过操作第一个函数来创建一个倒置的星号三角形。

我想出了这个函数和结果:

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


****
***
**
*

现在我必须操纵这些函数来创建一个向后的星号三角形。

   *
  **
 ***
****

还有一个倒置的星号三角形。

****
 ***
  **
   *

我应该实现哪些功能?

我曾尝试在函数后使用反向字符串命令 [::-1],但没有成功。

【问题讨论】:

  • 你不能只向后运行相同的循环吗?
  • 只是把它放在那里,但这些函数目前不是递归的。不确定这是否是要求的核心部分,但可能是。

标签: python ascii-art


【解决方案1】:

我之前已经回答了同样的问题。请记住,您提到的函数都不是recursive 函数。您可以阅读有关递归的更多信息here

这是我提到的例子here

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)

这里有一个递归函数的颠倒版本。

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)

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)

这里有一个递归函数的颠倒版本。

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)

编辑: 显示在我的 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)))

【讨论】:

  • 任何时候我输入你给我的代码并运行它,它都会在“print”之后的第二个引号上给出语法错误
  • @AkumaUkpo 我用一个替代的非递归函数以及我电脑上代码布局的屏幕截图更新了帖子。
  • link link 我截取了代码和错误消息的屏幕截图。我究竟做错了什么? @富士
  • 我添加了另一个版本的倒置金字塔。很难说,也许你正在运行 Python 3.X?我建议您也删除任何以前的代码,以确保它不是其他地方的类型。
  • 哦,对不起,我忘了说,是的,我正在运行 python 3.3.0 @Fuji
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-12-08
  • 2021-12-16
  • 1970-01-01
  • 1970-01-01
  • 2015-06-10
相关资源
最近更新 更多