Ootme 发表于 2019-12-17 16:01:08

关于第37讲的 乌龟程序

本帖最后由 Ootme 于 2019-12-17 17:26 编辑

import random as r

legal_x =
legal_y =

class Turtle:
    def __init__(self):
      # 初始体力
      self.power = 100
      # 初始位置随机
      self.x = r.randint(legal_x, legal_x)
      self.y = r.randint(legal_y, legal_y)

    def move(self):
      # 随机计算方向并移动到新的位置(x, y)
      new_x = self.x + r.choice()
      new_y = self.y + r.choice()
      # 检查移动后是否超出场景x轴边界
      if new_x < legal_x:
            self.x = legal_x - (new_x - legal_x)
      elif new_x > legal_x:
            self.x = legal_x - (new_x - legal_x)
      else:
            self.x = new_x
      # 检查移动后是否超出场景y轴边界
      if new_y < legal_y:
            self.y = legal_y - (new_y - legal_y)
      elif new_y > legal_y:
            self.y = legal_y - (new_y - legal_y)
      else:
            self.y = new_y      
      # 体力消耗
      self.power -= 1
      # 返回移动后的新位置
      return (self.x, self.y)

    def eat(self):
      self.power += 20
      if self.power > 100:
            self.power = 100

class Fish:
    def __init__(self):
      self.x = r.randint(legal_x, legal_x)
      self.y = r.randint(legal_y, legal_y)
      
    def move(self):
      # 随机计算方向并移动到新的位置(x, y)
      new_x = self.x + r.choice()
      new_y = self.y + r.choice()
      # 检查移动后是否超出场景x轴边界
      if new_x < legal_x:
            self.x = legal_x - (new_x - legal_x)
      elif new_x > legal_x:
            self.x = legal_x - (new_x - legal_x)
      else:
            self.x = new_x
      # 检查移动后是否超出场景y轴边界
      if new_y < legal_y:
            self.y = legal_y - (new_y - legal_y)
      elif new_y > legal_y:
            self.y = legal_y - (new_y - legal_y)
      else:
            self.y = new_y
      # 返回移动后的新位置
      return (self.x, self.y)

turtle = Turtle()
fish = []
for i in range(10):
    new_fish = Fish()
    fish.append(new_fish)

while True:
    if not len(fish):
      print("鱼儿都吃完了,游戏结束!")
      break
    if not turtle.power:
      print("乌龟体力耗尽,挂掉了!")
      break

    pos = turtle.move()
    # 在迭代器中删除列表元素是非常危险的,经常会出现意想不到的问题,因为迭代器是直接引用列表的数据进行引用
    # 这里我们把列表拷贝给迭代器,然后对原列表进行删除操作就不会有问题了^_^
    for each_fish in fish[:]:
      if each_fish.move() == pos:
            # 鱼儿被吃掉了
            turtle.eat()
            fish.remove(each_fish)
            print("有一条鱼儿被吃掉了...")



在这里 pos = turtle.move() 是什么意思?
那鱼的移动是在下面的 for 里面执行的吗

jackz007 发表于 2019-12-17 16:24:40

本帖最后由 jackz007 于 2019-12-17 16:32 编辑

      each_fish . move() 使一条鱼移动并返回这条鱼的当前位置座标,pos 是乌龟的当前位置座标,二者重合的时候,乌龟就可以把这条鱼吃掉。
      乌龟的移动是通过 while 循环驱动的,乌龟每移动一次,在后续 for 循环的驱动下,所有幸存的鱼儿也陆续移动一次。直到鱼儿被吃光或乌龟被累死。

Ootme 发表于 2019-12-17 16:39:17

jackz007 发表于 2019-12-17 16:24
each_fish . move() 使一条鱼移动并返回这条鱼的当前位置座标,pos 是乌龟的当前位置座标,二者重 ...

那程序的哪部分提示了乌龟的移动是while循环形成的啊

Ootme 发表于 2019-12-17 16:43:11

jackz007 发表于 2019-12-17 16:24
each_fish . move() 使一条鱼移动并返回这条鱼的当前位置座标,pos 是乌龟的当前位置座标,二者重 ...

还有我把 pos = turtle.move() 去掉然后把下面的pos 改成   turtle.move()为什么乌龟就不动了啊~~~

jackz007 发表于 2019-12-17 17:19:27

Ootme 发表于 2019-12-17 16:43
还有我把 pos = turtle.move() 去掉然后把下面的pos 改成   turtle.move()为什么乌龟就不动了啊~~~

         那就不要再下盲棋了呀,谁知道你的代码长啥样子。

Ootme 发表于 2019-12-17 17:22:46

import random as r

legal_x =
legal_y =

class Turtle:
    def __init__(self):
      # 初始体力
      self.power = 100
      # 初始位置随机
      self.x = r.randint(legal_x, legal_x)
      self.y = r.randint(legal_y, legal_y)

    def move(self):
      # 随机计算方向并移动到新的位置(x, y)
      new_x = self.x + r.choice()
      new_y = self.y + r.choice()
      # 检查移动后是否超出场景x轴边界
      if new_x < legal_x:
            self.x = legal_x - (new_x - legal_x)
      elif new_x > legal_x:
            self.x = legal_x - (new_x - legal_x)
      else:
            self.x = new_x
      # 检查移动后是否超出场景y轴边界
      if new_y < legal_y:
            self.y = legal_y - (new_y - legal_y)
      elif new_y > legal_y:
            self.y = legal_y - (new_y - legal_y)
      else:
            self.y = new_y      
      # 体力消耗
      self.power -= 1
      # 返回移动后的新位置
      return (self.x, self.y)

    def eat(self):
      self.power += 20
      if self.power > 100:
            self.power = 100

class Fish:
    def __init__(self):
      self.x = r.randint(legal_x, legal_x)
      self.y = r.randint(legal_y, legal_y)
      
    def move(self):
      # 随机计算方向并移动到新的位置(x, y)
      new_x = self.x + r.choice()
      new_y = self.y + r.choice()
      # 检查移动后是否超出场景x轴边界
      if new_x < legal_x:
            self.x = legal_x - (new_x - legal_x)
      elif new_x > legal_x:
            self.x = legal_x - (new_x - legal_x)
      else:
            self.x = new_x
      # 检查移动后是否超出场景y轴边界
      if new_y < legal_y:
            self.y = legal_y - (new_y - legal_y)
      elif new_y > legal_y:
            self.y = legal_y - (new_y - legal_y)
      else:
            self.y = new_y
      # 返回移动后的新位置
      return (self.x, self.y)

turtle = Turtle()
fish = []
for i in range(10):
    new_fish = Fish()
    fish.append(new_fish)

while True:
    if not len(fish):
      print("鱼儿都吃完了,游戏结束!")
      break
    if not turtle.power:
      print("乌龟体力耗尽,挂掉了!")
      break

    pos = turtle.move()
    # 在迭代器中删除列表元素是非常危险的,经常会出现意想不到的问题,因为迭代器是直接引用列表的数据进行引用
    # 这里我们把列表拷贝给迭代器,然后对原列表进行删除操作就不会有问题了^_^
    for each_fish in fish[:]:
      if each_fish.move() == pos:
            # 鱼儿被吃掉了
            turtle.eat()
            fish.remove(each_fish)
            print("有一条鱼儿被吃掉了...")

Ootme 发表于 2019-12-17 17:23:21

jackz007 发表于 2019-12-17 17:19
那就不要再下盲棋了呀,谁知道你的代码长啥样子。

额我怕太长了不好看我重新发到下面了

Ootme 发表于 2019-12-18 14:58:59

求助~~~~~~乌龟的行动在哪体现了~~

Ootme 发表于 2019-12-19 16:20:01

求助~~~~~

Ootme 发表于 2019-12-20 18:14:49


求助~~~~~
页: [1]
查看完整版本: 关于第37讲的 乌龟程序