我正在使用龟图来重现l系统(TurtleWorld库)。我试图应用的规则在它们不涉及回到之前保存的状态时工作得很好,但是每当有[和](参见下面的规则)时,事情就会中断并且乌龟只是随机抽取bs。
我认为,基本上,检查“]'存在位置的IF语句是代码断开的地方。 (另外,我知道目前还没有优化,为了清晰起见,我写了一个可靠的IF ...)
编辑:新代码 - 这个整个计算角度的东西不是必需的,因为我们有get_heading(),它告诉我们我们所面向的角度。
import turtle
turtle.down()
n = 'F'
s1 = 'F'
s2 = 'FF-[-F+F+F]+[+F-F-F]'
#s3 = 'F'
#s4 = 'FF'
steps = 5
for i in range(steps):
n = n.replace(s1,s2)
#n = n.replace(s3,s4)
a = 25
x = []
y = []
angle = []
for i in n:
if i == 'F':
turtle.forward(2)
if i == '+':
turtle.left(a)
if i == '-':
turtle.right(a)
if i=='[':
x.append(turtle.xcor())
y.append(turtle.ycor())
angle.append(turtle.heading())
if i==']':
turtle.pu()
turtle.setpos(x[len(x)-1],y[len(y)-1])
turtle.right(turtle.heading())
turtle.setheading(angle[len(angle)-1])
x.pop()
y.pop()
angle.pop()
turtle.pd()
答案 0 :(得分:2)
一些想法:
angle
- 处理程序中将newa
设置为新角度(]
)。newa>0
会将其左转。rt
处理负角度吗?pop
代替,并且推送了元组或某些状态,您可以大大简化代码。-1
的索引等于len(lst) - 1
。 pop
示例 - 建议:
>>> state = []
>>> angle = 90
>>> posx = 10
>>> posy = 15
>>> state.append((angle, posx, posy))
>>> angle = 40
>>> angle, posx, posy = state.pop()
>>> angle
90