Python数据结构与算法(上课笔记)---双端队列与无序表的实现

一、双端队列的代码实现

class Deque:
    def __init__(self):
        self.items=[]
    def isEmpty(self):
        return self.items==[]
    def addFront(self,item):
        self.items.append(item)
    def addRear(self,item):
        self.items.insert(0,item)
    def removeFront(self):
        return self.items.pop(-1)
    def removeRear(self):
        return self.items.pop(0)
    def size(self):
        return len(self.items)

二、双端队列的应用---回文词判定

算法流程:

1.先将需要判定的词从队尾加入deque

2.再从两端同时移除字符串判定是否相同,直到deque中只剩下0个或1个字符

代码实现:

def palchecker(aString):
    chardeque=Deque()
    for ch in aString:
        chardeque.addRear(ch)
    stillEqual=True
    while chardeque.size()>1 and stillEqual:
        first=chardeque.removeFront()
        last=chardeque.removeRear()
        if first!=last:
            stillEqual=False
    return stillEqual

三、无序表抽象数据类型 

1.链表实现(节点Node)

class Node():
    def __init__(self,initdata):
        self.data=initdata
        self.next=None
    def getData(self):
        return self.data
    def getNext(self):
        return self.next
    def setData(self,newdata):
        self.data=newdata
    def setNext(self,newnext):
        self.next=newnext

2.以链表实现无序表

可以采用链接节点的方式构建数据集来实现无序表

链表的第一个和最后一个节点最重要!!!

如果想访问到链表中的所有节点,就必须从第一个节点开始沿着节点遍历下去

设置一个属性head,保存对第一个节点的引用,空表的head为None

class UnorderedList:
    def __init__(self):
        self.head=None
mylist=UnorderedList()
print(mylist.head)#None

随着数据项的加入,无序表的head始终指向链条中的第一个节点

注意!无序表mylist对象本身并不包含数据项(数据项在节点当中)

其中包含的head只是对首个节点的引用,判断空表的isEmpty()很容易实现(return self.head ==None)

2.1实现add方法

根据性能考虑,最便捷的位置是表头

 

 

2.2链表实现size方法

size :从链条头head开始遍历到表尾同时用变量累加经过的节点个数(代价O(N))

 2.3链表实现search方法

从链表头head开始遍历到表尾,同时判断当前节点的数据项是否目标

 

2.4 链表实现:remove(item)方法

remove(item)代码 

 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

隔叶听风˗ˋˏ ˎˊ˗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值