当前位置: 首页 > news >正文

网站右侧滚动快速导航代码站长工具综合权重查询

网站右侧滚动快速导航代码,站长工具综合权重查询,济宁网站建设培训班,长沙有做网站的吗一、什么是链表数据? 链表是一种通过指针串联在一起的数据结构,每个节点由2部分组成,一个是数据域,一个是指针域(存放下一个节点的指针)。最后一个节点的指针域指向null(空指针的意思&#xff0…

一、什么是链表数据?
链表是一种通过指针串联在一起的数据结构,每个节点由2部分组成,一个是数据域,一个是指针域(存放下一个节点的指针)。最后一个节点的指针域指向null(空指针的意思),链表的入口节点称为链表的头结点也就是head
链表结构如下图在这里插入图片描述
二、链表的类型
1、单链表每个节点的指针指向一个方向,只可单方向查询数据,如上图所示。
2、双链表,每个节点可以有2个指针域,既可指向下一个节点,也可指向上一个节点,双链表既可以向前查询,也可以向后查询。
如图在这里插入图片描述3、循环链表:链表首尾相连,可以用来解决约瑟夫环问题。如图
在这里插入图片描述三、链表的存储方式
链表的存储于数组不同,数组在空间中可以是连续的,而链表是通过指针域的指针将不连续的数据存储在空间各个节点中的,因此指针节点在链表数据的应用中非常关键。所以链表中的节点在内存中不是连续分布的 ,而是散乱分布在内存中的某地址上,分配机制取决于操作系统的内存管理。
四、链表的定义
了解了链表的结构组成,我们来了解一下链表的Python 实现,链表作为一个类,他需要构造。

class ListNode:def __init__(self, val, next=None):##定义一个列表函数,包含数据值和指针()self.val = val #定义列表节点的self.val为valself.next = next #定义列表指针的self.next为next

五、常见的链表操作
1、删除节点在这里插入图片描述
如图想要删除D节点,就要先将D节点上一个指针指向E节点,在Python语言中,会自动将D节点释放掉,此时就可以删除D节点了。
2、节点添加
在这里插入图片描述如图想要在D节点前添加F节点,需要先把C节点指向F节点,然后再把F节点的指针指向D节点,在这个过程中Python系统会自动释放C到D的指针指向。

链表的增添和删除都是O(1)操作,也不会影响到其他节点。

但是要注意,要是删除第五个节点,需要从头节点查找到第四个节点通过next指针进行删除操作,查找的时间复杂度是O(n)。
六、链表和数组操作比较
在这里插入图片描述
数组在定义的时候,长度就是固定的,如果想改动数组的长度,就需要重新定义一个新的数组。

链表的长度可以是不固定的,并且可以动态增删, 适合数据量不固定,频繁增删,较少查询的场景。

Leetcode203题在这里插入图片描述

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:def removeElements(self, head: Optional[ListNode], val: int) -> Optional[ListNode]:cur=dummy=ListNode(next=head) ##构建一个虚拟哨兵节点,使得他的指针指向头结点while cur.next: ##当当前节点的指针存的时候if cur.next.val==val: ##如果当前节点的下一个节点的值等于指定的值,cur.next=cur.next.next #则删除下一个节点else:cur=cur.next #否则当前链表向下一个节点移动return dummy.next #返回链表(因为dummy是头结点前的一个虚拟节点,所以返回的是dummy.next)

在这里插入图片描述

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:def reverseList(self, head: Optional[ListNode]) -> Optional[ListNode]:cur=headpre=Nonewhile cur:tem=cur.next##保存cur后续数据cur.next=pre##cur指针方向改变pre=cur ##把当前的cur付给pre,进行下一次循环cur=tem ##把之前保存的cur后续数据再赋值给当前的cur,进行下一次循环return pre
http://www.mnyf.cn/news/37724.html

相关文章:

  • 网站中qq跳转怎么做的怎么打广告吸引客户
  • 做网站的哪里好百度app下载最新版
  • 哪个网站做漂流瓶任务网站换了域名怎么查
  • wordpress api key乐云seo官网
  • 做微信首图的网站福州网站seo
  • 饿了吗网站做的比较好的地方电脑培训班在哪里有最近的
  • 设计网站 知乎sem是什么职业岗位
  • 云南百度小程序开发站长之家seo工具包
  • 网站建设的实验总结打开百度网站
  • 怎么看网站后台网页尺寸百度网站下载安装
  • 响应式网站需要单独的网址吗网络营销策划需要包括哪些内容
  • 有没有做请帖的网站seo关键词快速获得排名
  • 微商城设计网站建设注册网站流程
  • 免费搭建商城网站广告公司联系方式
  • 响应式网站模板html北京做网络优化的公司
  • 网上购物网站模板网络营销的策略包括
  • 上海到北京高铁票价多少赣州网站seo
  • 网页编辑与网站编辑百度信息流推广
  • 做国际网站有什么需要注意的视频外链工具
  • wordpress直接显示文章重庆网站关键词排名优化
  • 自定义菜单WordPress广州网站制作实力乐云seo
  • 建立官方网站多少钱seo黑帽优化
  • 成都网站建设的公司哪家好seo外链推广工具下载
  • 欧洲大带宽服务器seo站长工具下载
  • 临清住房建设网站加盟教育培训哪个好
  • 网站如何做信息表西安网站关键词优化推荐
  • 厦门建站服务seo优化需要多少钱
  • 网页传奇开服表seo新站如何快速排名
  • 怎么用asp做网站培训机构好还是学校好
  • 定手机网站建设猪八戒网接单平台