4

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

1 回答 1

2

几个想法:

  • 您从未在-handler中设置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
于 2011-06-11T10:56:22.767 回答