位置: 编程技术 - 正文
推荐整理分享JavaScript数据结构之单链表和循环链表(javascript数据结构),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:javascript数据结构有哪些,javascript数据结构与算法,javascript数据结构与算法项目电话号码检查器,javascript数据结构与算法第三版,javascript数据结构与算法第三版,javascript数据结构,javascript数据结构与算法第三版pdf下载,javascript数据结构与算法 pdf,内容如对您有帮助,希望把文章链接给更多的朋友!
数据结构系列前言:
数据结构作为程序员的基本知识,需要我们每个人牢牢掌握。近期我也展开了对数据结构的二次学习,来弥补当年挖的坑。。。。。。 当时上课的时候也就是跟着听课,没有亲自实现任何一种数据结构,更别提利用数据结构来解决问题了。 现在就来填坑了奋斗 在这里提醒看到我博客的孩子们,如果你还是在校生,永远不要轻视任何一门基础课的学习,这个时候挖的坑,要么需要用双倍的努力去填,要么会直接影响一个人的能力等等。。。。。。 千万别给自己挖坑
进入正题,关于链表的数据结构知识,这里简单介绍下:
链表是一种物理存储单元上非线性、非连续性的数据结构(它在数据逻辑上是线性的),它的每个节点由两个域组成:数据域和指针域。数据域中存储实际数据,指针域则存储着指针信息,指向链表中的下一个元素或者上一个元素。正是由于指针的存在,链表的存储在物理单元是非连续性的。
链表的优点和缺点同样明显。和线性表相比,链表在添加和删除节点上的效率更高,因为其只需要修改指针信息即可完成操作,而不像线性表(数组)那样需要移动元素。同样的,链表的长度在理论上也是无限的(在存储器容量范围内),并可以动态变化长度,相比线性表优势很大。 相应的,由于线性表无法随机访问节点,只能通过指针顺着链表进行遍历查询来访问,故其访问数据元素的效率比较低。
下面是JS部分
这里面封装了的常用方法及描述:
方法 描述 append(element) 向链表尾部添加结点element insert(position,element) 向位置position处插入结点element removeAt(position) 按照索引值position删除结点 remove(element) 搜索并删除给定结点element remove() 删除链表中最后一个结点 indexOf(element) 查找并返回给定结点element的索引值 isEmpty() 判断链表是否为空 size() 获取链表长度 toString() 转换为字符串输出 getHead() 获取头结点 getTail() 获取尾结点
对于各常用方法的算法描述在这里就不写了,相信大家都可以轻易读懂并理解,毕竟都是非常基础的知识了。
单链表:
循环链表:在单链表的基础上,将尾节点的指针指向头结点,就构成了一个循环链表。环形链表从任意一个节点开始,都可以遍历整个链表。
使用方法:
在类外部扩充方法:
标签: javascript数据结构
本文链接地址:https://www.jiuchutong.com/biancheng/373281.html 转载请保留说明!友情链接: 武汉网站建设