IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> Python 如何判断一个对象是否为单链表的节点 -> 正文阅读

[数据结构与算法]Python 如何判断一个对象是否为单链表的节点

单链表节点类的初始化

class Node():

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

判断对象类型的两种方法

type() 或 instance(),用它们来测试:

>>> a,b,c = Node(),Node(1),Node(1,Node(2))
>>> type(a)==Node,type(b)==Node,type(c) is Node
(True, True, True)
>>> isinstance(a,Node),isinstance(b,Node),isinstance(c,Node)
(True, True, True)
>>> 

>>> num = 1
>>> type(num)==Node
False
>>> isinstance(num, Node)
False
>>> 

>>> nil = None
>>> type(nil)==Node
False
>>> isinstance(nil, Node)
False
>>> 

那么这样就够了吗?其实还存在问题:

>>> node1=Node(1,2)
>>> node2=Node(1,Node(2))
>>> node1
Node(1->2)
>>> node2
Node(1->2->None)
>>> isinstance(node1,Node)
True
>>> isinstance(node2,Node)
True
>>> isinstance(node1.next,Node)
False
>>> isinstance(node2.next,Node)
True

上面的测试中:node1的.next是整数2,也被认为是Node;但节点的本义 .next是要指向另一个节点的,所以要同时判断node和node.next都为Node才能认为它是节点:

>>> node1=Node(1,2)
>>> node2=Node(1,Node(2))
>>> isinstance(node1,Node) and isinstance(node1.next,Node)
False
>>> isinstance(node2,Node) and isinstance(node2.next,Node)
True
>>> 

改写成判断函数

>>> class Node():
	def __init__(self, value=None, Next=None):
		self.val = value
		self.next = Next
	def isNode(node):
		return isinstance(node,Node) and isinstance(node.next,Node)

	
>>> node1=Node(1,2); node2=Node(1,Node(2))
>>> node1.isNode()
False
>>> node2.isNode()
True
>>> 
>>> node3=Node()
>>> node3.isNode()
False
>>> node4=Node(1)
>>> node4.isNode()
False
>>> 

可以判断出.next值不是节点的“伪节点”了,但对空节点和单个节点来说,它们的 .next 值是None,显然也要加以判断,还好 isinstance的第二参数可以接收各种类型值作为元素的元组:

>>> class Node():
	def __init__(self, value=None, Next=None):
		self.val = value
		self.next = Next
	def isNode(node):
		return isinstance(node,Node) and isinstance(node.next,(Node,type(None)))

		
>>> node1=Node()
>>> node1.isNode()
True
>>> node2=Node(1)
>>> node2.isNode()
True
>>>

但又有一个小问题,如果用这个函数来判断其它类型数据,会不会返错?想过没有其它类型可就不一定有.next属性:

>>> num = 1
>>> num.next
Traceback (most recent call last):
  File "<pyshell#55>", line 1, in <module>
    num.next
AttributeError: 'int' object has no attribute 'next'
>>> nil = None
>>> nil.next
Traceback (most recent call last):
  File "<pyshell#57>", line 1, in <module>
    nil.next
AttributeError: 'NoneType' object has no attribute 'next'
>>> 
>>> Node.isNode(num)
False
>>> Node.isNode(nil)
False
>>> 

思考:为什么没有.next属性的数据类型照常能够正确判断出是非节点呢?

原因很简单,因为逻辑“与”运算 and 有个特性: A and B ,如果A==True整个式子就是True,根本不会去判断B,不管它是True还是False,甚至它即使是错的也不会管。所以这个判断式 isinstance(node,Node) and isinstance(node.next,(Node,type(None))) 是可以正常工作的,也就是说这个 isNode() 是成功的。

......

更多内容,请见:

Python 触“类”旁通2|数据结构入门之单链表

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-08-05 17:36:08  更:2021-08-05 17:39:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 18:21:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码