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|数据结构入门之单链表

  • 12
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hann Yang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值