# LC 2130. Maximum Twin Sum of a Linked List
### [Problem link](https://leetcode.com/problems/maximum-twin-sum-of-a-linked-list/)
###### tags: `leedcode` `python` `medium` `Linked List`
In a linked list of size <code>n</code>, where <code>n</code> is **even** , the <code>i<sup>th</sup></code> node ( **0-indexed** ) of the linked list is known as the **twin** of the <code>(n-1-i)<sup>th</sup></code> node, if <code>0 <= i <= (n / 2) - 1</code>.
- For example, if <code>n = 4</code>, then node <code>0</code> is the twin of node <code>3</code>, and node <code>1</code> is the twin of node <code>2</code>. These are the only nodes with twins for <code>n = 4</code>.
The **twin sum ** is defined as the sum of a node and its twin.
Given the <code>head</code> of a linked list with even length, return the **maximum twin sum** of the linked list.
**Example 1:**
<img alt="" src="https://assets.leetcode.com/uploads/2021/12/03/eg1drawio.png" style="width: 250px; height: 70px;" />
```
Input: head = [5,4,2,1]
Output: 6
Explanation:
Nodes 0 and 1 are the twins of nodes 3 and 2, respectively. All have twin sum = 6.
There are no other nodes with twins in the linked list.
Thus, the maximum twin sum of the linked list is 6.
```
**Example 2:**
<img alt="" src="https://assets.leetcode.com/uploads/2021/12/03/eg2drawio.png" style="width: 250px; height: 70px;" />
```
Input: head = [4,2,2,3]
Output: 7
Explanation:
The nodes with twins present in this linked list are:
- Node 0 is the twin of node 3 having a twin sum of 4 + 3 = 7.
- Node 1 is the twin of node 2 having a twin sum of 2 + 2 = 4.
Thus, the maximum twin sum of the linked list is max(7, 4) = 7.
```
**Example 3:**
<img alt="" src="https://assets.leetcode.com/uploads/2021/12/03/eg3drawio.png" style="width: 200px; height: 88px;" />
```
Input: head = [1,100000]
Output: 100001
Explanation:
There is only one node with a twin in the linked list having twin sum of 1 + 100000 = 100001.
```
**Constraints:**
- The number of nodes in the list is an **even** integer in the range <code>[2, 10<sup>5</sup>]</code>.
- <code>1 <= Node.val <= 10<sup>5</sup></code>
## Solution 1 - Linked-List and List
```python=
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def pairSum(self, head: Optional[ListNode]) -> int:
pair = []
res = 0
while head:
pair.append(head.val)
head = head.next
for i in range(len(pair)//2):
res = max(res, pair[i] + pair[-(i + 1)])
return res
```
## Solution 2 - Linked-List
```python=
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def pairSum(self, head: Optional[ListNode]) -> int:
# reverse the first half of head
fast = head
cur = head
pre = None
while fast and fast.next:
fast = fast.next.next
tmp = cur.next
cur.next = pre
pre = cur
cur = tmp
# cal maximum
res = float("-inf")
while cur and pre:
res = max(res, cur.val + pre.val)
cur = cur.next
pre = pre.next
return res
```
>### Complexity
>n = The number of nodes in the list
>| | Time Complexity | Space Complexity |
>| ----------- | --------------- | ---------------- |
>| Solution 1 | O(n) | O(n) |
>| Solution 2 | O(n) | O(1) |
## Note
x