python链表的乘法问题

美女程序员鼓励师

说明

1、左乘法约定为数乘,即乘以整数n,链表的长度增加n倍。

尝试非数乘的情况:即当两个链表相乘时,用它们的数据域对应相乘的各个节点的值。

2、右乘法也要重载,否则右乘number*Node会报错,加一行:__rmul__=__mul__。

实例

   def __mul__(self, other):

        if type(other) is Node:

            n1,n2 = self.values,other.values

            product = [p[0]*p[1] for p in zip(n1,n2)]

            return Node.build(product)

        if other<0 or type(other) is not int:

            raise TypeError("other is a non-negetive Integer")

        if other==0:return Node()

        ret = self.copy()

        for _ in range(1,other):

            self += ret

        return self

 

    __rmul__ = __mul__

 

 

'''

>>> a = Node() + range(1,3)

>>> a * 0

Node(None->None)

>>> a * 1

Node(1->2->None)

>>> a * 2

Node(1->2->1->2->None)

>>> a * 5

Node(1->2->1->2->1->2->1->2->1->2->None)

>>>

>>> 3 * a

Node(1->2->1->2->1->2->None)

>>> a

Node(1->2->None)

>>> a *= 5

>>> a

Node(1->2->1->2->1->2->1->2->1->2->None)

>>>

>>>

>>> a = Node() + range(1,8)

>>> b = Node(2) * 7

>>> a * b

Node(2->4->6->8->10->12->14->None)

>>> b * a

Node(2->4->6->8->10->12->14->None)

>>>

'''

以上就是python链表的乘法问题,希望对大家有所帮助。更多Python学习指路:python基础教程

本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。

以上是 python链表的乘法问题 的全部内容, 来源链接: utcz.com/z/545678.html

回到顶部