mirror of
https://github.com/halfrost/LeetCode-Go.git
synced 2025-07-25 12:14:26 +08:00
46 lines
763 B
Go
46 lines
763 B
Go
package leetcode
|
|
|
|
import (
|
|
"github.com/halfrost/LeetCode-Go/structures"
|
|
)
|
|
|
|
// ListNode define
|
|
type ListNode = structures.ListNode
|
|
|
|
/**
|
|
* Definition for singly-linked list.
|
|
* type ListNode struct {
|
|
* Val int
|
|
* Next *ListNode
|
|
* }
|
|
*/
|
|
|
|
func swapPairs(head *ListNode) *ListNode {
|
|
if head == nil || head.Next == nil {
|
|
return head
|
|
}
|
|
s := head.Next
|
|
var behind *ListNode
|
|
for head.Next != nil {
|
|
headNext := head.Next
|
|
if behind != nil && behind.Next != nil {
|
|
behind.Next = headNext
|
|
}
|
|
var next *ListNode
|
|
if head.Next.Next != nil {
|
|
next = head.Next.Next
|
|
}
|
|
if head.Next.Next != nil {
|
|
head.Next = next
|
|
} else {
|
|
head.Next = nil
|
|
}
|
|
headNext.Next = head
|
|
behind = head
|
|
if head.Next != nil {
|
|
head = next
|
|
}
|
|
}
|
|
return s
|
|
}
|