C语言链表交换相邻节点,LeetCode 24--两两交换链表中的节点 ( Swap Nodes in Pairs ) ( C语言版 )...

题目描述  :

3416b4e1de0a629b902f34176d643df8.png

解题思路 : 分为两种情况处理 , 当要交换的节点是链表的前两个节点时 , 当交换的节点非前两个节点时 ;

代码如下 :

/**

* Definition for singly-linked list.

* struct ListNode {

* int val;

* struct ListNode *next;

* };

*/

struct ListNode* swapPairs(struct ListNode* head) {

if(head==NULL)

return NULL;

if(head->next==NULL)

return head;

struct ListNode* a=head;

struct ListNode* b=head->next;

struct ListNode* tail;

a->next=b->next;

b->next=a;

head=b;

tail=a;

a=a->next;

if(a==NULL||a->next==NULL)

return head;

else{

while(a&&a->next){

b=a->next;

a->next=b->next;

tail->next=b;

b->next=a;

tail=a;

a=a->next;

}

}

return head;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值