python链接列表部分反转

2024-06-24 13:42:38 发布

您现在位置:Python中文网/ 问答频道 /正文

我在课堂上有一个链表

7,5,3,1,2,4,6,8

我想得到这样的输出

1,3,5,7,2,4,6,8

当我尝试使用下面的反向代码时:

class Linkedlist:
def __init__(self, L = None):
...
def partlyreverse(self):
    tail = self.head
    current_node = self.head.next_node
    tail.next_node = None
    while current_node.value % 2 == 1:
        next_current_node = current_node.next_node
        current_node.next_node = tail
        tail = current_node
        current_node = next_current_node

    self.head = tail
L = Linkedlist([7,5,3,1,2,4,6,8])
L.partlyreverse()

我只能

1,3,5,7

那我怎么做呢?你知道吗

谢谢!你知道吗


Tags: 代码selfnonenodeinitdefcurrenthead
2条回答

你基本上需要检查你的列表开始持有奇数或偶数!基于此,你需要逆转!你知道吗

>>> s
(7, 3, 5, 1, 2, 4, 6, 8)
>>> sorted(filter(lambda x:(x%2!=0 and s[0]%2!=0) or (x%2==0 and s[0]%2==0),s)) + sorted(filter(lambda x:(x%2!=0 and s[-1]%2!=0) or (x%2==0 and s[-1]%2==0),s))
[1, 3, 5, 7, 2, 4, 6, 8]

你的问题不是100%清楚:你是不是想把链表一分为二,开头是奇数,结尾是偶数?您是否试图在不考虑值本身的情况下对列表进行分区?你知道吗

另外,一定有一些代码,你还没有提交你的问题…我已经采取了我的最佳猜测,可能是什么样的代码。你知道吗

下面的代码段将返回所需的输出:

class Node:
    def __init__(self, value):
        self.value = value
        self.next_node = None

class Linkedlist:
    def __init__(self, L=None):
        self.head = Node(L[0])
        current = self.head
        for value in L[1:]:
            current.next_node = Node(value)
            current = current.next_node

    def partlyreverse(self):
        tail_start = self.head
        tail_end = self.head
        tail2_start = None
        tail2_end = None

        current_node = self.head.next_node

        while current_node != None:
            if current_node.value % 2 == 1:
                next_current_node = current_node.next_node
                current_node.next_node = tail_start
                tail_start = current_node
                current_node = next_current_node
            else:
                if not tail2_start:
                    tail2_start = current_node
                    tail2_end = tail2_start
                    current_node = current_node.next_node             
                else:
                    tail2_end.next_node = current_node
                    tail2_end = current_node
                    current_node = current_node.next_node 

        tail_end.next_node = tail2_start
        self.head = tail_start

L = Linkedlist([7,5,3,1,2,4,6,8])

L.partlyreverse()

def RecursivelyPrintNodes(node):
    if node != None:
        print node.value
        RecursivelyPrintNodes(node.next_node)

RecursivelyPrintNodes(L.head)

# 1,3,5,7,2,4,6,8

最后,我了解了您在代码中的意图,但需要注意的是,您编写的代码无法编译(类中存在缩进错误)。你知道吗

相关问题 更多 >