我应该编写一个程序,最终结果如下:
* *
* *
* *
*
我有为常规代码编写的代码,但我不确定如何将空格合并到其中。
def triangle(i, t = 0):
if i == 0
return 0
else:
print ' ' * (t + 1) + '*' * (i * 2 - 1)
return triangle(i - 1, t + 1)
建议?
让我们在一行中标记一些区域:
startSpaces * middleSpaces * endSpaces
对于给定的行,您希望startSpaces
+ 1 + middleSpaces
+ 1 +endSpaces
等于一个常数。这个常数是2*(i+t) + 1
第1行将
在最后一行之前有t=0
空格(这里我使用的是原始的,我知道它通过递归而改变)*
t=i
*
i
那么你能找到 的模式,startSpaces
这会给你正确的模式吗?middleSpaces
endSpaces
请记住,您将需要一个额外的else if
案例,i==1
以便您可以仅使用一个案例来处理该行*
这应该足以让您更接近解决您的问题。我假设这是家庭作业,所以我不会为您解决,如果您遇到困难,请寻求更多线索。
尝试:
def triangle(i, t = 0):
if i == 0:
print (t+1) *' '+ '*'
else:
print ' ' * (t + 1)+ '*' + ' ' * (i * 2 - 1) + '*'
triangle(i - 1, t + 1)
triangle(5)
此代码打印:
* *
* *
* *
* *
* *
*
基于@kharazi 的回答(因为这让我想起了我早期的 GWBasic 编程,这让我小时候对编程感到兴奋):
def triangle(i, leftShape='*', rightShape='*', bottomShape='*', spaceShape=' ', t = 0):
if i <= 0:
print ((t+1)*spaceShape)+bottomShape+((t+1)*spaceShape)
else:
print (spaceShape*(t + 1))+leftShape+(spaceShape*(i*2-1))+rightShape+(spaceShape*(t + 1))
triangle(i-1, leftShape, rightShape, bottomShape, spaceShape, t+1)
if __name__== '__main__':
triangle(3)
triangle(3, '\\', '/')
triangle(3, '\\', '/', '~')
triangle(5, '╚╗', '╔╝', '╚╦╝')
triangle(5, '╚╗', '╔╝', '╚╦╝', '|')
triangle(-2)
产生以下输出:
triangle(3)
* *
* *
* *
*
triangle(3, '\\', '/')
\ /
\ /
\ /
*
triangle(3, '\\', '/', '~')
\ /
\ /
\ /
~
triangle(5, '╚╗', '╔╝', '╚╦╝')
╚╗ ╔╝
╚╗ ╔╝
╚╗ ╔╝
╚╗ ╔╝
╚╗ ╔╝
╚╦╝
triangle(5, '╚╗', '╔╝', '╚╦╝', '|')
|╚╗|||||||||╔╝|
||╚╗|||||||╔╝||
|||╚╗|||||╔╝|||
||||╚╗|||╔╝||||
|||||╚╗|╔╝|||||
||||||╚╦╝||||||
triangle(-2)
*
您应该为此使用 for 循环,递归有效,但始终使用它并不是最好的主意。这就是我所做的:
def GioTri(i):
foo = i - 1
bar = 0
for i in range(i-1):
print ' ' * bar + "*" + " " * (foo*2 - 1) + "*" + " " * bar
foo = foo - 1
bar = bar + 1
print " " * bar + "*" + " " * bar
结果如下所示:
* *
* *
* *
*