zoukankan      html  css  js  c++  java
  • 数据结构_链表(单链表,单向循环链表,双链表)

    单链表
    '''
    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

    2020-05-07

  • 相关阅读:
    若依问题解决(一)
    Java 将两个List转换为流合并List
    后端返回前端文本换行显示,只能在前端再转换
    Java Stream() 流根据对象属性去重
    vue 当前端传回后端,后端使用实体类接收数据显示报错
    js 中 getMonth() 获取的月份比现实少一个月
    vue连个数组对比
    JS链接跳转方法
    ElementUI--表格toggleRowSelection无法选中
    Linux 常用命令
  • 原文地址:https://www.cnblogs.com/hany-postq473111315/p/12845339.html
Copyright © 2011-2022 走看看