链表逆置的两种方法

原链表图:

 

方法一:头插法链表逆置

1.断开头节点与其他节点的连接(提前存好head->next的地址)

    Node* p = head->next;

    Node* q = p->next;

    head->next = NULL;

2. 头插法在head后面插入p后链表的各个节点

    p->next = head->next;

    head->next = p;

p、q指针往后移

    p = q;

    if (q != NULL)

          q = q->next;

3. 依此类推直到全部插入,链表逆置完成

完整代码:

void R_head(List head)
{
	assert(head != NULL);
	if (head == NULL)
		return;
	if (GetLength(head) <= 1)
		return;
	Node* p = head->next;
	Node* q = p->next;
	head->next = NULL;
	while (p != NULL)
	{
		p->next = head->next;
		head->next = p;
		p = q;
		if (q != NULL)
			q = q->next;
	}
	return;
}

 方法二:三个指针直接逆置

1.设置三个指针分别指向head后面的三个节点

    Node* p = head->next;

    Node* q = p->next;

    Node* r = q->next;

2. p第一个指向的节点(head->next)的指针域赋为空

    p->next = NULL;

3. 把q的next指向q,然后p,q,r往后移(r是为了存逆置前q的next)

        q->next = p;

        p = q;

        q = r;

        r = r->next;

4. 当r指向空时,不再后移,将head的next指向q

    q->next = p;

    plist->next = q;

 完整代码:

void R(List head)
{
	assert(head != NULL);
	if (head == NULL)
		return;
	if (GetLength(head) <= 1)
		return;
	Node* p = head->next;
	Node* q = p->next;
	Node* r = q->next;
	p->next = NULL;
	while (r != NULL)
	{
		q->next = p;
		p = q;
		q = r;
		r = r->next;
	}
	q->next = p;
	head->next = q;
}

三指针相对复杂。

如果链表长度为1或0则不需要逆置直接return。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

曦樂~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值