comments | difficulty | edit_url | tags | |||
---|---|---|---|---|---|---|
true |
Medium |
|
You are given an arbitrary node
from a doubly linked list, which contains nodes that have a next pointer and a previous pointer.
Return an integer array which contains the elements of the linked list in order.
Example 1:
Input: head = [1,2,3,4,5], node = 5
Output: [1,2,3,4,5]
Example 2:
Input: head = [4,5,6,7,8], node = 8
Output: [4,5,6,7,8]
Constraints:
- The number of nodes in the given list is in the range
[1, 500]
. 1 <= Node.val <= 1000
- All nodes have unique
Node.val
.
We can start from the given node and traverse the linked list backward until we reach the head node. Then, we traverse the linked list forward from the head node, adding the values of the nodes we encounter to the answer array.
After the traversal is complete, return the answer array.
The time complexity is
"""
# Definition for a Node.
class Node:
def __init__(self, val, prev=None, next=None):
self.val = val
self.prev = prev
self.next = next
"""
class Solution:
def toArray(self, node: "Optional[Node]") -> List[int]:
while node.prev:
node = node.prev
ans = []
while node:
ans.append(node.val)
node = node.next
return ans
/*
// Definition for a Node.
class Node {
public int val;
public Node prev;
public Node next;
};
*/
class Solution {
public int[] toArray(Node node) {
while (node != null && node.prev != null) {
node = node.prev;
}
var ans = new ArrayList<Integer>();
for (; node != null; node = node.next) {
ans.add(node.val);
}
return ans.stream().mapToInt(i -> i).toArray();
}
}
/**
* Definition for doubly-linked list.
* class Node {
* int val;
* Node* prev;
* Node* next;
* Node() : val(0), next(nullptr), prev(nullptr) {}
* Node(int x) : val(x), next(nullptr), prev(nullptr) {}
* Node(int x, Node *prev, Node *next) : val(x), next(next), prev(prev) {}
* };
*/
class Solution {
public:
vector<int> toArray(Node* node) {
while (node && node->prev) {
node = node->prev;
}
vector<int> ans;
for (; node; node = node->next) {
ans.push_back(node->val);
}
return ans;
}
};
/**
* Definition for a Node.
* type Node struct {
* Val int
* Next *Node
* Prev *Node
* }
*/
func toArray(node *Node) (ans []int) {
for node != nil && node.Prev != nil {
node = node.Prev
}
for ; node != nil; node = node.Next {
ans = append(ans, node.Val)
}
return
}
/**
* Definition for _Node.
* class _Node {
* val: number
* prev: _Node | null
* next: _Node | null
*
* constructor(val?: number, prev? : _Node, next? : _Node) {
* this.val = (val===undefined ? 0 : val);
* this.prev = (prev===undefined ? null : prev);
* this.next = (next===undefined ? null : next);
* }
* }
*/
function toArray(node: _Node | null): number[] {
while (node && node.prev) {
node = node.prev;
}
const ans: number[] = [];
for (; node; node = node.next) {
ans.push(node.val);
}
return ans;
}