b2科目四模拟试题多少题驾考考爆了怎么补救
b2科目四模拟试题多少题 驾考考爆了怎么补救

java 循环链表 使用python实现链表操作

电脑杂谈  发布时间:2018-02-14 09:38:40  来源:网络整理

instanceof_concurrenthashmap_java 循环链表

链表是计算机科学里面应用最广泛的数据结构之一。这篇文章主要介绍了使用python实现链表操作,需要的朋友可以参考下

一、概念梳理

链表是计算机科学里面应用应用最广泛的数据结构之一。它是最简单的数据结构之一,同时也是比较高阶的数据结构(例如栈、环形缓冲和队列)

简单的说,一个列表就是单数据通过索引集合在一起。java 循环链表在C里面这叫做指针。比方说,一个数据元素可以由地址元素,地理元素、路由信息活着交易细节等等组成。但是链表里面的元素类型都是一样的,是一种特殊的列表。

一个单独的列表元素叫做一个节点。这些节点不像数组一样都按顺序存储在内存当中,相反,你可以通过一个节点指向另外一个节点的指针在内存不同的地方找到这些元素。列表最后一项习惯用NIL表示,相当于python里面的None

这里介绍两种不同的列表——单链表和双链表。双链表中的某个节点只会指向列表中的下一个元素,但是在双链表里面,当前节点同时也会指向前一个节点。所以双链表会占用更多的内存,因为它需要额外的变量去存储索引

图一、单链表

图2:双链表

单链表可以从头到尾顺序查询,但是反过来就不是那么容易了。然而,双链表不管你是从哪个节点开始,从任意方向查询都是一样的。在单链表中增加和删除节点只需要两步,但是在双链表里就需要四步了。

但是在python里面没有提供像双链表一样的数据结构,所以我们可以自己创建一个这样的数据结构

二、如果使用python创建链表

(1).将节点定义成一个数据结构

首先我们将节点类定义成ListNode,该类在初始化实例对象时,定义了两个实例变量,其中data用来存储节点的值,next用来存储下一个节点的索引,下面详细介绍一下一个节点要定义的方法和属性

上面的方法和属性涵盖了一个节点应有的基本属性和行为

Listing1:The ListNode class

上面创建了最简单的节点类,下面初始化ListNode的对象

Listing2:初始化节点

上面创建了三个独立的节点

(2)创建一个单链表类

现在我们定义一个名为SingleLinkedList的类去管理我们的节点,它包含了下面这些方法:

java 循环链表_concurrenthashmap_instanceof

下面一一讲解这些方法

__init__()定义了head和tail,都初始化为None

Listing3:The SingleLinkedList class(part one)

(3)、添加节点

通过add_list_item()添加列表元素。先检测是不是ListNode的实例,如果不是,就新建一个节点。如果列表还是空的话,就把该节点当作头节点,如果不是空,就将当前节点指向下一个元素(也就是刚新添加的节点)。把新节点添加到列表当中

Listing4:The SinglelinkedList class(part two)

list_length()方法计算节点数量,返回列表的长度。java 循环链表在一个循环当中循环列表,self.next依次指向下一个节点

Listing5:The SingleLinkedList class(part three)

output_list()用来输出新的节点值

Listing6:The SingleLinkedList class(part four)

下面我们初始化SingleLinkedList的实例track,然后创建4个节点。

(4)查询列表

查询整个列表使用unordered_search()。它需要使用一个额外的参数帮助查询。列表的头是切入点。

(5)、从列表中移除一个元素

从列表中移除一个节点 时,指向该节点索引需要被移动到,被移除节点的下一个节点。被移除的节点会由python的垃圾回收机制清除

Listing10:Removing a node by node number

(6)、创建一个双链表

创建双链表其实就是在ListNode的基础上,在创建一个previous的属性

Listing11:Extended list node class

instanceof_java 循环链表_concurrenthashmap

然后我们就可以依据上面的定义新建一个双链表类

添加新的节点跟单链表有所不同

移除双链表中的节点

python实际运用

输出结果

(7)、使用队列实现双向列表

相关阅读 :

Python 实现链表实例代码

使用Python实现BT和磁力链接的相互转换

浅谈Python单向链表的实现

使用python实现拉钩网上的FizzBuzzWhizz问题示例

python双向链表示例代码

使用python实现baidu hi自动登录的代码

使用Python实现下载网易云音乐的高清MV的代码

使用python实现正则匹配检索远端FTP目录下的文件

使用Python实现一个简单的项目监控示例

使用python实现strcmp函数功能示例

菜鸟使用python实现正则检测密码合法性

使用python实现省市三级菜单效果


本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-fly.com/a/jisuanjixue/article-77137-1.html

    相关阅读
      发表评论  请自觉遵守互联网相关的政策法规,严禁发布、暴力、反动的言论

      热点图片
      拼命载入中...