python 手写队列

#encoding=utf8
class MQueue:
    def __init__(self):
        self.data = []

    def get(self):
        if self.data.__len__()>0:
            return self.data.pop()
        else:
            return None

    def put(self, item):
        if not self.isExist(item):
            self.data.insert(0, item)

    def remove(self, obj, attr='name'):#移除某个属性等于obj的所有对象
        while -1 != self.indexOf(obj):
            self.data.pop(self.indexOf(obj))

    def size(self):
        return self.data.__len__()

    def isEmpty(self):
        return 0 == self.data.__len__()

    def indexOf(self, obj, attr='name'):#查询对象indexOf(obj),查询元素indexOf(obj.str,obj.attr)
        isDict = isinstance(obj, dict)
        for i in range(self.data.__len__()):
            if (isDict and self.data[i] == obj) or (not isDict and obj == self.data[i][attr]):
                return i
        return -1

    def isExist(self, obj):
        return not -1 == self.indexOf(obj)

    def getData(self):
        return self.data

if __name__ == '__main__':
    q = MQueue()
    q.put({'name': '路人甲'})
    q.put({'name': '路人1'})
    q.put({'name': '路人2'})
    q.put({'name': '路人3'})
    q.put({'name': '路人甲'})
    print(q.size())
    q.remove('路人甲')
    print(q.size())
    print(q.isExist('路人1'))

 

转载于:https://www.cnblogs.com/lurenjia1994/p/9604987.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值