2

整数を取り、その数の行で構成されるアスタリスクの三角形を返す再帰関数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]を使用しようとしましたが、機能しませんでした。

4

1 に答える 1

5

私はすでに同じ質問に先に答えました。あなたが言及した関数はどれも関数ではないことに注意してください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)

そして、ここに再帰関数の逆さまのバージョンがあります。

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:Python3.x で動作するコードを追加しました

Edit3:Python3.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)))
于 2013-03-22T00:44:22.450 に答える