|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
class CountList(list):
def __init__(self, *args):
super().__init__(args)
self.count = []
for i in args:
self.count.append(0)
def __len__(self):
return len(self.count)
def __getitem__(self, key):
self.count[key] += 1
return super().__getitem__(key)
def __setitem__(self, key, value):
self.count[key] += 1
super().__setitem__(key, value)
def __delitem__(self, key):
del self.count[key]
super().__delitem__(key)
def counter(self, key):
return self.count[key]
def append(self, value):
self.count.append(0)
super().append(value)
def pop(self, key=-1):
del self.count[key]
return super().pop(key)
def remove(self, value):
key = super().index(value)
del self.count[key]
super().remove(value)
def insert(self, key, value):
self.count.insert(key, 0)
super().insert(key, value)
def clear(self):
self.count.clear()
super().clear()
def reverse(self):
self.count.reverse()
super().reverse()
这是答案 在代码中,def reverse(self):
self.count.reverse()
super().reverse(),这种self.count.reverse()的作用不就是调用reverse函数 那后面super().reverse()作用不就重复了?这串代码看的好蒙 有没有大佬能详细讲一下 谢谢了
本帖最后由 Twilight6 于 2020-6-18 16:45 编辑
我输了 看看我们都扯多少时间了
这里的pop 和remove都是super().remove(value),return super().pop(key) 这种调用父类的方法
是为了使我们重写的有原来list 的 功能,
def __delitem__(self, key):
当你容器内元素被删除时候就会被调用!
休息去了
|
|