鱼C论坛

 找回密码
 立即注册
查看: 759|回复: 3

[已解决]课后作业第37讲运行为什么没有结果

[复制链接]
发表于 2020-4-17 22:30:01 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
import random as r

legal_x = [0,10]
legal_y = [0,10]

class Turtle:
    def __init__(self):
        self.power = 100

        self.legal_x = r.randint(legal_x[0],legal_x[1])
        self.legal_y = r.randint(legal_x[0],legal_y[1])


    def move(self):
        new_legal_x = self.legal_x +r.choice([1,-1,2,-2])
        new_legal_y = self.legal_y +r.choice([1,-1,2,-2])

        if new_legal_x >= legal_x[1]:
            self.legal_x = legal_x[1] - (new_legal_x - legal_x[1])
        elif new_legal_x <= legal_x[0]:
            self.legal_x = legal_x[0] - (new_legal_x - legal_x[0])
        else:
            self.legal_x = new_legal_x

        if new_legal_y >= legal_y[1]:
            self.legal_y = legal_y[1] - (new_legal_y - legal_y[1])
        elif new_legal_y <= legal_y[0]:
            self.legal_y = legal_y[0] - (new_legal_y - legal_x[0])

        else:
            self.legal_y = new_legal_y
            
        self.power -= 1

        return (self.legal_x,self.legal_y)
        
            

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

class Fish:
    def __init__(self):
        self.legal_x = r.randint(legal_x[0],legal_x[1])
        self.legal_y = r.randint(legal_x[0],legal_y[1])


    def move(self):
        new_legal_x = self.legal_x +r.choice([1,-1])
        new_legal_y = self.legal_y +r.choice([1,-1])

        if new_legal_x >= legal_x[1]:
            self.legal_x = legal_x[1] - (new_legal_x - legal_x[1])
        elif new_legal_x <= legal_x[0]:
            self.legal_x = legal_x[0] - (new_legal_x - legal_x[0])

        if new_legal_y >= legal_y[1]:
            self.legal_y = legal_y[1] - (new_legal_y- legal_y[1])
        elif new_legal_y <= legal_y[0]:
            self.legal_y = legal_y[0] - (new_legal_y - legal_x[0])

        else:
            self.legal_x = new_legal_x
            self.legal_y = new_legal_y

        return (self.legal_x,self.legal_y)


turtle = Turtle()
fish = []

for i in range(10):
    new_fish = Fish()
    fish.append(new_fish)

while 1:
    if len(fish)==0 :
        print('鱼没了')
        break
    if turtle.power == 0:
        print('龟死了')
        break
   

    pos = Turtle.move
    for each in fish[:]:
        if each.move() == pos:
            Turtle.eat()
            fish.remove(each)
            print('有一条鱼被吃了')
   
        
   

        
            
最佳答案
2020-4-17 23:02:04
错都在最后一段,改好就行了。
 pos = turtle.move()               #大写改小写,加一对括号
    for each in fish[:]:
        if each.move() == pos:
            turtle.eat()                        #大写改小写
            fish.remove(each)
            print('有一条鱼被吃了')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-17 22:34:07 | 显示全部楼层
算法太慢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-17 23:02:04 | 显示全部楼层    本楼为最佳答案   
错都在最后一段,改好就行了。
 pos = turtle.move()               #大写改小写,加一对括号
    for each in fish[:]:
        if each.move() == pos:
            turtle.eat()                        #大写改小写
            fish.remove(each)
            print('有一条鱼被吃了')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-17 23:04:49 | 显示全部楼层
       if new_legal_x >= legal_x[1]:
            self.legal_x = legal_x[1] - (new_legal_x - legal_x[1])
        elif new_legal_x <= legal_x[0]:
            self.legal_x = legal_x[0] - (new_legal_x - legal_x[0])

        if new_legal_y >= legal_y[1]:
            self.legal_y = legal_y[1] - (new_legal_y- legal_y[1])
        elif new_legal_y <= legal_y[0]:
            self.legal_y = legal_y[0] - (new_legal_y - legal_x[0])

        else:
            self.legal_x = new_legal_x
            self.legal_y = new_legal_y

红线部分应该是上个else 里面的代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-26 14:53

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表