一道 Python 类的笔试题详解
博客专区 > MtrS 的博客 > 博客详情
一道 Python 类的笔试题详解
MtrS 发表于3年前
一道 Python 类的笔试题详解
  • 发表于 3年前
  • 阅读 204
  • 收藏 12
  • 点赞 0
  • 评论 0

新睿云服务器60天免费使用,快来体验!>>>   

<!-- lang: python -->

 r = {} 
class C(object):
   def __init__(self, a, b):
        self.a = a
        self.b = b
        if b == 'a':
            orig = super(C, cls)
            r[cls.instance] = 1

a = C(1, 'a')
b = C(1, 'a')
c = C(1, 'b')
l = [a, b, c] 
for i in l:
if i not in r:
    r[i] = 1  
else:
    r[i] += 1

assert r[a] == 2
assert r[b] == 2 
assert r[c] == 1 

原题目要求如下: 修改 C 类, 使得下面的 断言成立:

要想使下面的断言成立,既需要满足 item in r , 而 a 和 b 同属于 C 类, 且参数一致, a 初次赋值 给 r 字典的时候, r[a] = 1, b 赋值给 r 字典的时候 更改 使得 r[b] = r[a] + 1 此时 r[a] = r[b] =2 即满足 题目要求, 要使得 r[b] = r[a] + 1 此时需要 hash(a) == hash(b) , 在类里面满足 hash(self) , 使得 a,b 哈西值一致。

另外需要满足的时 给 r[b] 赋值时, 字典自身检测到 字典已经包含该 键, 类 需要满足一个方法 eq(self, other): 使得 a == b

最后个人的解决方法:

<!-- lang: python -->

class C(object):

def __init__(self, a, b):
    self.a = a
    self.b = b

def __eq__(self, other):
    return self.a == other.a and self.b== other.b

def __hash__(self):
    return self.a
  • 打赏
  • 点赞
  • 收藏
  • 分享
共有 人打赏支持
粉丝 29
博文 468
码字总数 351660
×
MtrS
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: