第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

【金秋打卡】第17+計(jì)算機(jī)組成原理

標(biāo)簽:
Java

  • 第一模块:5-2、5-3双向链表的原理与实践、

  • 讲师姓名:咚咚呛

  • 第二模块:课程内容(内容概述)


删除的实现. 删除节点 改变上一个节点的尾部指向下一个节点 改变下一个节点的头部指向上一个节点

代码实现:
链表节点——存放Key-Value数据
双向链表——从头部增加节点;从尾部增加节点;
删除任意节点;增加任意节点;
取出头部节点;取出尾部节点。
"""双向链表的实现"""


class Node:
    """双向链表节点"""
    def __init__(self, key, val, next=None, prev=None):
        self.key = key
        self.val = val
        self.next = next  # 下一个节点
        self.prev = prev  # 上一个节点
    
    def __str__(self):
        val = '{%d: %d}' % (self.key, self.val)
        return val


class DoubleLinkList:
    """双向链表
    def __init__(self, capacity=0xffff):
        self.capacity = capacity
        self.head = None
        self.tail = None
        self.size = 0  # 链表大小
    
    def __add_head(self, node):
        """私有方法,向头部添加新节点"""
        if not self.head:
            self.head = node
            self.tail = node
            self.head.next = None
            self.head.prev = None
        else:
            node.next = self.head
            self.head.prev = node
            self.head = node
            self.head.prev = None
        self.size += 1
        return node
    
    def __add_tail(self, node):
        """私有方法,向尾部添加新节点"""
        if not sefl.tail:
            self.tail = node
            self.head = node
            self.tail.next = None
            self.tail.prev = None
        else:
            sefl.tail.next = node
            node.prev = self.tail
            self.tail = node
            self.tail.next = None
        self.size = 1
        return node
        
    def __del_tail(self):
        """私有方法,删除尾部节点"""
        if not self.tail:
            return
        node = self.tail
        if node.prev:
            self.tail = node.prev
            self.tail.next = None
        else:
            self.tail = self.head = None
        self.size -= 1
        return node
    
    def __del_head(self):
        """私有方法,删除头部节点"""
        if not self.head:
            return
        node = self.head
        if node.next:
            self.next = node.next
            self.head.prev = None
        else:
            self.tail = self.head = None
        self.size -= 1
        return node
    
    def __remove(self, node):
        """私有方法,移除任意节点"""
        # 如果node为None,默认删除尾部节点
        if not node:
            node = self.tail
        if node == self.tail:
            self.__del_tail()
        elif node == self.head:
            self.__del_head()
        else:
            node.prev.next = node.next
            node.next.prev = node.prev
            self.size -= 1
        return node
    
    def pop(self):
        """弹出结尾元素"""
        return self.__del_head()
    
    def append(self, node):
        """向结尾添加节点"""
        return self.__add_tail(node)
        
    def append_front(self.node):
        """向头部添加节点"""
        return sefl.__add_head(node)
        
    def remove(sefl, node=None):
        """删除任意节点"""
        return sefl.__remove(node)
        
    def print(self):
        """打印链表内容"""
        p = self.head
        line = ''
        while p:
            line += '%s' % p
            p = p.next
            if p:
                line += "=>"
        print(line)


點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消