一、题目
二、算法分析
我主要想着通过while循环自己交换,前面两个单独考虑,后面的都是一样的处理。
因为前面的两个需要交换两次,后面的需要交换三次
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */ class Solution { public: ListNode* swapPairs(ListNode* head) { //如果为空,返回 if( head==NULL ) return head; //如果不为空 ListNode* pre = head; ListNode* lat; ListNode* former=head; int flag = 0; while(pre!=NULL && pre->next != NULL ){ lat = pre->next; //交换节点 //former->next = lat; if(flag==0){ pre->next = lat->next; lat->next = pre; //更新 former = pre; pre = pre->next; //设置头节点 head = lat; flag = 1; } else{ former->next = lat; pre->next = lat->next; lat->next = pre; //更新 former = pre; pre = pre->next; } //更新 //pre = pre->next; //former = pre; } return head; } };
三、参考代码
作者提供的思路很好:
public ListNode swapPairs(ListNode head) { if(head == null || head.next == null){ return head; } ListNode next = head.next; head.next = swapPairs(next.next); next.next = head; return next; }