我正在使用海龟图形来重现 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()