链表反转的实现

//链表的反转递归和非递归实现
#include<stdio.h>
#include<stdlib.h>
typedef struct Node{
	int data;
	struct Node* next;
}Node;

//迭代法反转链表,
// p从指向第一个结点开始,当p存在,用s记录当前结点位置, 并让p后移记录下一个结点的位置,
//让当前结点的后继指针,指向其前驱结点,反转完成后head指向当前结点,表示当前结点为新的头
//由于反转链表后,第一个元素结点的后继指针,将变为NULL,所以在第一次反转前,让head为空
//在不停反转过程中,head始终指向当前完成反转的那个结点。直到最后一个结点反转完成,此时Head指向原链表的最后一个结点,该结点成为新的头
Node* reserveList1(Node* head)
{
	Node *p = NULL, *s = NULL;
	p = head;
	head = NULL;
	while (p)  //当p存在
	{
		s = p; //s保存当前结点
		p = p->next; //p保存下一个结点
		s->next = head; //s指向其前驱
		head = s;      //s成为新的头
	}

	return head;
}

//递归法。

Node* reserveList2(Node *h)
{
	if (h == NULL || h->next == NULL)
		return h;
	Node* NewHead = reserveList2(h->next);

	h->next->next = h;
	h->next = NULL;

	return NewHead;
}

//循环打印链表
void printList(Node* head)
{
	while (head != NULL)
	{
		printf("%d ", head->data);
		head = head->next;
	}
}



int main02()
{
	//创建一个链表
	Node s1, s2,s3,s4,s5;
	s1.data = 1;
	s2.data = 2;
	s3.data = 3;
	s4.data = 4;
	s5.data = 5;
	s1.next = &s2;
	s2.next = &s3;
	s3.next = &s4;
	s4.next = &s5;
	s5.next = NULL;

	//打印原始链表
	printList(&s1);
	printf("*******************\n");
	//打印迭代法反转后的链表
	//printList(reserveList1(&s1));
	printf("*******************\n");
	//打印递归法反转后的链表
	printList(reserveList2(&s1));
	system("pause");

}

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值