python 链表结构练习

class Node(object):
    __slots__ = ['val', 'next']

    def __init__(self, val, next=None):
        self.val = val
        self.next = next

class SingleLinkedList(object):
    """单向链表结构实现"""
    def __init__(self):
        self._head = None  # 第一个元素指针
        self._last = None  # 最后一个元素指针
        self._size = 0

    def __str__(self):
        """完整的打印链表结构"""
        arr = []
        current = self._head
        while current is not None:
            arr.append(str(current.val))
            current = current.next
        return "{0}({1})".format(__class__, "=>".join(arr))

    def __len__(self):
        """返回链表大小"""
        return self._size

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

    def append(self, val):
        """链表末尾增加元素"""
        node = Node(val)
        if self.is_empty():
            self._head = node
            self._last = node
        else:
            self._last.next = node
            self._last = node
        self._size += 1

    def add(self, val):
        """链表首部增加元素"""
        node = Node(val)
        if self.is_empty():
            self._head = node
            self._last = node
        else:
            node.next = self._head
            self._head = node
        self._size += 1

    def insert(self, pos, val):
        """固定位置插入元素"""
        node = Node(val)
        if pos <= 0:
            self.add(val)
        elif pos >= self._size:
            self.append(val)
        else:
            count = 1
            pre = self._head
            current = self._head.next
            while current is not None:
                if count == pos:
                    pre.next = node
                    node.next = current
                else:
                    current = current.next
                count += 1
        self._size += 1

    def index(self, val):
        """返回某个值的索引,未找到返回-1"""
        index = 0
        current = self._head
        while current is not None:
            if current.val == val:
                return index
            else:
                current = current.next
            index += 1
        return -1

    def get(self, index):
        """根据索引返回节点"""
        count = 0
        current = self._head
        if index < 0 or index >= self._size:
            raise Exception("IndexError: list index out of range")
        while current is not None:
            if count == index:
                return current
            else:
                current = current.next
            count += 1

    def remove(self, val):
        """删除某个值"""
        index = 0
        pre = None
        current = self._head
        while current is not None:
            if current.val == val:
                if pre is None:
                    self._head = self._head.next
                else:
                    pre.next = current.next
                self._size -= 1
                return
            else:
                pre = current
                current = current.next
            index += 1
        raise Exception("ValueError: remove(x): x not in list")

    def clear(self):
        """清空链表"""
        self._head = None
        self._size = 0
        self._last = None

    def pop(self, pos):
        """根据索引删除元素并返回"""
        count = 0
        pre = None
        current = self._head
        if pos < 0 or pos >= self._size:
            raise Exception("IndexError: pop index out of range")
        while current is not None:
            if count == pos:
                if pre is None:
                    self._head = self._head.next
                else:
                    pre.next = current.next
                self._size -= 1
                return current
            else:
                pre = current
                current = current.next
            count += 1

    def reverse(self):
        """反转链表结构"""
        if self._size <= 1:
            return self
        pre = self._head
        current = self._head.next
        pre.next = None
        self._last = pre
        while current is not None:
            next_node = current.next
            if next_node is None:
                # 到最后了,末尾元素变第一
                self._head = current
                print(self)
            current.next = pre
            pre = current
            current = next_node


if __name__ == '__main__':
    s = SingleLinkedList()
    print(s.is_empty())
    for i in range(10):
        s.append(i)
    print("append 1~10", s)
    print("size: ", len(s))
    print("index(3)", s.index(3))
    # print("index(13)", s.index(13))
    print("get(3)", s.get(3), s.get(3).val)
    # print("get(13)", s.get(13))
    print("pop(9)", s.pop(9).val, s)
    print("pop(5)", s.pop(5).val, s)
    print("size: ", len(s))
    print("remove(6)", s.remove(6), s)
    print("remove(0)", s.remove(0), s)
    print("size: ", len(s))
    print("s.reverse()", s.reverse(), s)
    s.add(-1)
    print("add(-1)", s)
    s.add(-2)
    print("add(-2)", s)
    s.append(0)
    print("append(0)", s)
    print("size: ", len(s))
    s1 = SingleLinkedList()
    print("s1: ", s1)
    s1.insert(1, 1)
    print("insert(1,1)", s1)
    s1.insert(2, 2)
    print("insert(2,2)", s1)
    s1.insert(1, 3)
    print("insert(1,3)", s1)
    s1.insert(0, 4)
    print("insert(1,3)", s1)


链表结构练习题:

https://leetcode-cn.com/problems/add-two-numbers/

image.png

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def addTwoNumbers(self, l1: ListNode, l2: ListNode) -> ListNode:
        head = result = ListNode(0)
        t = 0
        while l1 is not None or l2 is not None:
            if l1 is not None:
                t += l1.val
                l1 = l1.next
            if l2 is not None:
                t += l2.val
                l2 = l2.next
            result.next = ListNode(t % 10)
            result = result.next
            t = t // 10
        # 最后一位的时候如果大于0需要进1
        if t > 0:
            result.next = ListNode(t)
        return head.next

if __name__=='__main__':
    s = Solution()
    l1 = ListNode(3)
    l2 = ListNode(4, next=l1)
    l3 = ListNode(2, next=l2)
    l4 = ListNode(4)
    l5 = ListNode(6, next=l4)
    l6 = ListNode(5, next=l5)
    L1 = l3
    L2 = l6
    r = s.addTwoNumbers(L1, L2)
    c = r

    while c is not None:
        print(c.val, end='')
        c = c.next
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,667评论 5 472
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,361评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,700评论 0 333
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,027评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,988评论 5 361
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,230评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,705评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,366评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,496评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,405评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,453评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,126评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,725评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,803评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,015评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,514评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,111评论 2 341

推荐阅读更多精彩内容