sinat_35318364 2020-06-07 07:51 采纳率: 100%
浏览 522
已采纳

Python中如何更新Class类中的自定义变量

问题如题

class Environment():

    grid_end = 9         
    grid_size = grid_end + 1
    init_food = 5           
    food_del_chance = 0.05 
    food_add_chance = 0.20

    def __init__(self):
        self.food = set()
        for i in range(self.init_food):
            X = random.randint(0, self.grid_end)
            Y = random.randint(0, self.grid_end)
            if not ((X,Y) in self.food):
                self.food.add((X,Y))
        print("Food at", end=" ")
        print(self.food)


    def clock_tick(self):
    # possibly delete food items -- copy elements not deleted into new set
        food_set = set()
        for location in self.food:
            r = random.random()
            if (r > self.food_del_chance):
                food_set.add(location)
            else:
                print("Food disappears at", end=" ")
                print(location)
        #print(food_set)
        self.food = food_set

在Class中的def clock-tick中,把food-set赋值给了self.food,但是self.food并没有更新,还是保持原来的set()。请问如何修改才能让self.food更新?
完整程序连接:https://pan.baidu.com/s/1jpYoqm4eKk5vOvIgYtJDjw
密码:llgj

也许并不是在class Environment()中没更新,可能在class agent中读取时一直读取的是原来的数据。头大。

终于发现问题了,问题存在于class agent中,集合更新使用了self.food-seen.update(percepts)。update会添加新元素进入set(),但是对于消失的元素不会进行删除。

  • 写回答

1条回答 默认 最新

  • threenewbee 2020-06-07 09:21
    关注

    我这里测试,food是可以被更新的啊。

    #!/usr/bin/python
    import random
    
    class Environment():
    
        grid_end = 9         
        grid_size = grid_end + 1
        init_food = 5           
        food_del_chance = 0.05 
        food_add_chance = 0.20
    
        def __init__(self):
            self.food = set()
            for i in range(self.init_food):
                X = random.randint(0, self.grid_end)
                Y = random.randint(0, self.grid_end)
                if not ((X,Y) in self.food):
                    self.food.add((X,Y))
            print("Food at", end=" ")
            print(self.food)
    
    
        def clock_tick(self):
        # possibly delete food items -- copy elements not deleted into new set
            food_set = set()
            for location in self.food:
                r = random.random()
                if (r > self.food_del_chance):
                    food_set.add(location)
                else:
                    print("Food disappears at", end=" ")
                    print(location)
            #print(food_set)
            self.food = food_set
            print(self.food)
    ev = Environment()
    ev.clock_tick()
    print(ev.food)
    
    

    Food at {(2, 7), (6, 4), (0, 6), (6, 7), (3, 5)}
    Food disappears at (0, 6)
    {(6, 7), (3, 5), (6, 4), (2, 7)}
    {(6, 7), (3, 5), (6, 4), (2, 7)}

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)