数据结构 巩固

数据结构_链表(单链表,单向循环链表,双链表)
单链表
'''
is_empty()          链表是否为空
length()            查询链表长度
travel()            遍历整个链表
add(item)           链表头部添加元素
append(item)        链表尾部添加元素
insert(pos,item)    指定位置添加元素
remove(item)        删除节点
search(item)        查找节点是否存在
'''
class SingleNode(object):
    '''单链表的节点'''
    def __init__(self,item):
        self.item = item
        # 数据域
        self.next = None
        # 指针域next指向下一个节点

    def is_empty(self):
        '''判断链表是否为空,看头结点是否为空'''
        return self._head == None

    def length(self):
        '''链表长度,遍历链表,每遍历一次就进行加一操作'''
        cur = self._head
        #令cur当前指向头节点位置
        count = 0  #count用来返回单链表长度
        while cur != None:
            count = count + 1
            cur = cur.next #到达下一个指针域
        return count

    def travel(self):
        '''遍历单链表,对遍历到的单链表元素取出数据域输出'''
        cur = self._head#指向头结点
        while cur != None:
            print(cur.item)#输出当前节点的元素
            cur = cur.next#指向下一个节点
        print(" ")

    def add(self,item):
        '''在单链表头部添加数据域为item元素的节点,
        使包含有item元素的节点的下一个节点为头结点(没进行添加之前的)'''
        node = SingleNode(item)
        # 创建连接,使头结点为第二个节点
        node.next = self._head
        # 对头结点进行重新命名
        self._head = node

    def append(self,item):
        '''尾部添加元素,当单链表为空时,直接添加。
            当单链表不为空时,在尾部添加(进行遍历操作,直到最后一个节点)'''
        # 创建节点元素存放item元素
        node = SingleNode(item)
        if self.is_empty():#如果链表为空
            self._head = node
        else:
            cur = self._head  #令指针指向头结点
            while cur.next != None:#进行遍历
                cur = cur.next#依次向下进行遍历,直到最后一个节点
            cur.next = node#让最后一个节点为node,包含有item的元素的节点

    def insert(self,pos,item):
        '''在指定pos位置,添加包含有item元素的节点'''
        if pos <= 0:
            #当pos为小于等于0的位置时,将item添加在头部
            self.add(item)
        elif pos >= self.length():
            # 当pos大于等于链表长度时,将item添加在尾部
            self.append(item)
        else:#既不在头部,又不在尾部
            '''创建pre指针,指向pos的前一个位置'''
            node = SingleNode(item)
            # 存储item元素的节点
            count = 0
            # pre用来指向位置pos的前一个位置pos-1,从头结点开始
            pre = self._head
            while count < pos - 1:
                # 当count为pos-1时,pre为要插入位置的前一个节点
                count += 1
                pre = pre.next
            node.next = pre.next #先连接原来链表中pos位置后面节点左面的线
            pre.next = node#连接原来链表中前一个节点的右面的线

    def remove(self,item):
        cur = self._head
        pre = None
        while cur != None:
            # 当单链表不为空时
            if cur.item == item:
                # 如果cur所指向的节点的元素item与要删除的item元素一致
                if not pre:
                    # pre 如果还是None 说明是头结点
                    # pre = None
                    # print(not pre) # True
                    self._head = cur.next#当前cur指向第一个节点
                #   cur.next为原链表的第二个节点
                else:
                    #cur为要删除的节点,但不是头结点
                    '''pre为cur的前一个节点,cur为要删除的节点
                       使用cur节点的后一个节点的左连线连接删除节点的前一个元素的右连线'''
                    pre.next = cur.next
            else:#当cur指向的节点所包含的item元素不是要寻找的item时
                pre = cur
                cur = cur.next #继续向下寻找

    def search(self,item):
        '''查看链表中是否存在item元素,通过遍历进行查找'''
        cur = self._head #指向头结点
        while cur != None:#当cur指向的不为空时
            if cur.item == item:#当找到该元素时
                return True
            cur = cur.next#在while循环内部,不断进行遍历
        return False

单向循环链表
'''
is_empty()          链表是否为空
length()            查询链表长度
travel()            遍历整个链表,到头节点结束
add(item)           链表头部添加元素(头节点作为下一个节点,最后一个节点为node节点)
append(item)        链表尾部添加元素,头节点为node的下一个节点
insert(pos,item)    指定位置添加元素
remove(item)        删除节点
search(item)        查找节点是否存在
'''
class Node(object):
    """节点"""
    def __init__(self, item):
        self.item = item
        self.next = None


class SinCycLinkedlist(object):
    """单向循环链表"""
    def __init__(self):
        self._head = None

    def is_empty(self):
        """判断链表是否为空"""
        return self._head == None

    def length(self):
        """返回链表的长度"""
        # 如果链表为空,返回长度0
        if self.is_empty():
            return 0
        count = 1
        cur = self._head
        while cur.next != self._head:
            count += 1
            cur = cur.next
        return count

    def travel(self):
        """遍历链表"""
        if self.is_empty():
            return
        cur = self._head
        print (cur.item,)
        while cur.next != self._head:
            cur = cur.next
            print(cur.item,)
        print ("")


    def add(self, item):
        """头部添加节点"""
        node = Node(item)
        if self.is_empty():
            self._head = node
            node.next = self._head
        else:
            #添加的节点指向_head
            node.next = self._head
            # 移到链表尾部,将尾部节点的next指向node
            cur = self._head
            while cur.next != self._head:
                cur = cur.next
            cur.next = node
            #_head指向添加node的
            self._head = node

    def append(self, item):
        """尾部添加节点"""
        node = Node(item)
        if self.is_empty():
            self._head = node
            node.next = self._head
        else:
            # 移到链表尾部
            cur = self._head
            while cur.next != self._head:
                cur = cur.next
            # 将尾节点指向node
            cur.next = node
            # 将node指向头节点_head
            node.next = self._head

    def insert(self, pos, item):
        """在指定位置添加节点"""
        if pos <= 0:
            self.add(item)
        elif pos > (self.length()-1):
            self.append(item)
        else:
            node = Node(item)
            cur = self._head
            count = 0
            # 移动到指定位置的前一个位置
            while count < (pos-1):
                count += 1
                cur = cur.next
            node.next = cur.next
            cur.next = node

    def remove(self, item):
        """删除一个节点"""
        # 若链表为空,则直接返回
        if self.is_empty():
            return
        # 将cur指向头节点
        cur = self._head
        pre = None
        # 若头节点的元素就是要查找的元素item
        if cur.item == item:
            # 如果链表不止一个节点
            if cur.next != self._head:
                # 先找到尾节点,将尾节点的next指向第二个节点
                while cur.next != self._head:
                    cur = cur.next
                # cur指向了尾节点
                cur.next = self._head.next
                self._head = self._head.next
            else:
                # 链表只有一个节点
                self._head = None
        else:
            pre = self._head
            # 第一个节点不是要删除的
            while cur.next != self._head:
                # 找到了要删除的元素
                if cur.item == item:
                    # 删除
                    pre.next = cur.next
                    return
                else:
                    pre = cur
                    cur = cur.next
            # cur 指向尾节点
            if cur.item == item:
                # 尾部删除
                pre.next = cur.next

    def search(self, item):
        """查找节点是否存在"""
        if self.is_empty():
            return False
        cur = self._head
        if cur.item == item:
            return True
        while cur.next != self._head:
            cur = cur.next
            if cur.item == item:
                return True
        return False

双向链表
'''
is_empty()          链表是否为空
length()            查询链表长度
travel()            遍历整个链表
add(item)           链表头部添加元素
append(item)        链表尾部添加元素
insert(pos,item)    指定位置添加元素
remove(item)        删除节点
search(item)        查找节点是否存在
'''
class Node(object):
    """双向链表节点"""
    def __init__(self, item):
        self.item = item
        self.next = None
        self.pre = None


class DLinkList(object):
    """双向链表"""
    def __init__(self):
        self._head = None

    def is_empty(self):
        """判断链表是否为空"""
        return self._head == None

    def length(self):
        """返回链表的长度"""
        cur = self._head
        count = 0
        while cur != None:
            count += 1
            cur = cur.next
        return count

    def travel(self):
        """遍历链表"""
        cur = self._head
        while cur != None:
            print(cur.item,)
            cur = cur.next
        print(" ")

    def add(self, item):
        """头部插入元素"""
        node = Node(item)
        if self.is_empty():
            # 如果是空链表,将_head指向node
            self._head = node
        else:
            # 将node的next指向_head的头节点
            node.next = self._head
            # 将_head的头节点的pre指向node
            self._head.pre = node
            # 将_head 指向node
            self._head = node

    def append(self, item):
        """尾部插入元素"""
        node = Node(item)
        if self.is_empty():
            # 如果是空链表,将_head指向node
            self._head = node
        else:
            # 移动到链表尾部
            cur = self._head
            while cur.next != None:
                cur = cur.next
            # 将尾节点cur的next指向node(先左后右)
            cur.next = node
            # 将node的pre指向cur
            node.pre = cur

    def search(self, item):
        """查找元素是否存在"""
        cur = self._head
        while cur != None:
            if cur.item == item:
                return True
            cur = cur.next
        return False

    def insert(self, pos, item):
        """在指定位置添加节点"""
        if pos <= 0:
            self.add(item)
        elif pos > (self.length()-1):
            self.append(item)
        else:
            node = Node(item)
            cur = self._head
            count = 0
            # 移动到指定位置的前一个位置
            while count < (pos-1):
                count += 1
                cur = cur.next
            # 将node的pre指向cur(node左右,cur右左)
            node.pre = cur
            # 将node的next指向cur的下一个节点
            node.next = cur.next
            # 将cur的下一个节点的pre指向node
            cur.next.pre = node
            # 将cur的next指向node
            cur.next = node

    def remove(self, item):
            """删除元素"""
            if self.is_empty():
                return
            else:
                cur = self._head
                if cur.item == item:
                    # 如果首节点的元素即是要删除的元素
                    if cur.next == None:
                        # 如果链表只有这一个节点
                        self._head = None
                    else:
                        # 将第二个节点的pre设置为None
                        cur.next.pre = None
                        # 将_head指向第二个节点
                        self._head = cur.next
                    return
                while cur != None:
                    if cur.item == item:
                        # 将cur的前一个节点的next指向cur的后一个节点
                        cur.pre.next = cur.next
                        # 将cur的后一个节点的pre指向cur的前一个节点
                        cur.next.pre = cur.pre
                        break
                    cur = cur.next
数据结构_队列(普通队列和双端队列)
队列
'''
Queue()         创建一个空队列
enqueue(item)   添加元素
dequeue()       从队列头部删除一个元素
is_empty()      判断一个队列是否为空
size()          返回队列的大小
'''
class Queue(object):
    '''队列'''
    def __init__(self):
        self.items = []

    def is_empty(self):
        return self.items == []

    def enqueue(self,item):
        '''进队列'''
        self.items.insert(0,item)

    def dequeue(self):
        '''出队列'''
        return self.items.pop()

    def size(self):
        '''返回队列的大小'''
        return len(self.items)

双端队列
'''
Deque()             创建一个空的双端队列
add_front(item)     从队头加入一个item元素
add_rear(item)      从队尾加入一个item元素
remove_front()      从队头删除一个item元素
remove_rear()       从队尾删除一个item元素
is_empty()          判断双端队列是否为空
size()              返回队列的大小
'''

class Deque(object):
    '''双端队列'''
    def __init__(self):
        self.items = []

    def is_empty(self):
        """判断队列是否为空"""
        return self.items == []

    def add_front(self,item):
        """在队头添加元素"""
        self.items.insert(0,item)

    def add_rear(self,item):
        """在队尾添加元素"""
        self.items.append(item)

    def remove_front(self):
        """从队头删除元素"""
        return self.items.pop(0)

    def remove_rear(self):
        """从队尾删除元素"""
        return self.items.pop()

    def size(self):
        """返回队列大小"""
        return len(self.items)
数据结构_栈
'''
Stack()         创建一个新的空栈
push(item)      添加一个新的元素item到栈顶
pop()           弹出栈顶元素
peek()          返回栈顶元素
is_empty()      判断栈是否为空
size()          返回栈的元素个数
'''
class Stack(object):
    '''栈'''
    def __init__(self):
        self.items = []

    def is_empty(self):
        """判断是否为空"""
        return self.items == []

    def push(self,item):
        """加入元素"""
        self.items.append(item)

    def pop(self):
        """弹出元素"""
        return self.items.pop()

    def peek(self):
        """返回栈顶元素"""
        return self.items[len(self.items)-1]

    def size(self):
        return len(self.items)

数据结构_二叉树
二叉树的创建
class Node(object):
    """节点类"""
    def __init__(self, elem=-1, lchild=None, rchild=None):
        self.elem = elem
        self.lchild = lchild
        self.rchild = rchild

class Tree(object):
    """树类"""
    def __init__(self, root=None):
        self.root = root

    def add(self, elem):
        """为树添加节点"""
        node = Node(elem)
        #如果树是空的,则对根节点赋值
        if self.root == None:
            self.root = node
        else:
            queue = []
            queue.append(self.root)
            #对已有的节点进行层次遍历
            while queue:
                #弹出队列的第一个元素
                cur = queue.pop(0)
                if cur.lchild == None:
                    cur.lchild = node
                    return
                elif cur.rchild == None:
                    cur.rchild = node
                    return
                else:
                    #如果左右子树都不为空,加入队列继续判断
                    queue.append(cur.lchild)
                    queue.append(cur.rchild)

二叉树的层次遍历
def breadth_travel(self, root):
    """利用队列实现树的层次遍历"""
    if root == None:
        return
    queue = []
    queue.append(root)
    while queue:
        node = queue.pop(0)
        print(node.elem,)
        if node.lchild != None:
            queue.append(node.lchild)
        if node.rchild != None:
            queue.append(node.rchild)

二叉树的深度遍历
def preorder(self, root):
    """递归实现先序遍历"""
    if root == None:
        return
    print(root.elem)
    self.preorder(root.lchild)
    self.preorder(root.rchild)


def inorder(self, root):
    """递归实现中序遍历"""
    if root == None:
        return
    self.inorder(root.lchild)
    print(root.elem)
    self.inorder(root.rchild)


def postorder(self, root):
    """递归实现后序遍历"""
    if root == None:
        return
    self.postorder(root.lchild)
    self.postorder(root.rchild)
    print(root.elem)

 

 

 

posted @ 2021-01-04 19:38  CodeYaSuo  阅读(101)  评论(0编辑  收藏  举报