单链表
线性表有两种:顺序表和链表
- 单链表
链表的一个结点包含 数据区和链接区。
箭头方向为单方向的为单向链表,也叫单链表。需要有一个头节点p指向单链表的头第一个节点的位置,表示单链表的地址,最后一个位置为尾结点,指向空。
- python中如何赋值变量的本质
a=10
先找到一块内存,存放整数10,然后再找到一块内存a,存放整数10所在的地址,从而建立连接。a=10 表示a所存储的内容指向10所在的地址。等号前面是存放地址,等号右边是对象。
将两个变量的值互换a,b=b,a
设a=10,b=20,则此代码表示的含义是:将b所指向的对象10所在的地址存到内存a里,将a所指向的对象20所在的地址存到b上。结果就是将a和b所指向的地址变了一下,10和20的地址没变。
- 设置节点 python代码
class Node(object):
"节点" #类文档字符串,可通过ClassName.__doc__查看
def __init__(self,elem): #构造函数
self.elem = elem
self.next = None
- 设置单链表及各种属性 python代码
class SingleLinkList(object):
"单链表"
def __init__(self,node=None): #头节点默认为空,若不输入则为空链表
self.__head = node #将头节点设为私密属性
def is_empty(self):
"判断是否为空链表"
return self.__head == None
def length(self):
"求链表长度"
#current游标,用来移动遍历节点
cur = self.__head
#count记录数量
count = 0
while cur != None:
count += 1
cur = cur.next
return count
def travel(self):
"遍历整个链表"
cur = self.__head
while cur != None:
print(cur.elem, end = ' ') #打印完一个元素用空格隔开,不加end默认换行
cur = cur.next
print('') #换行
def append(self,item):
"在尾部添加元素,尾插法"
node = Node(item)
if self.is_empty():
self.__head = node
else:
cur = self.__head
while cur.next != None:
cur = cur.next
cur.next = node
def addFirst(self,item):
"在头部添加元素,头插法"
node = Node(item)
node.next = self.__head
self.__head = node
def insert(self,index,item):
"""在指定位置添加元素
:param index 从0开始
"""
node = Node(item)
if index <= 0