链表逆序

设链表节点为 :
typedef struct tagListNode{  
	int data;  
	struct tagListNode* next;  
}ListNode, *List;

要求将一带链表头List head的单向链表逆序 
分析: 
  1). 若链表为空或只有一个元素,则直接返回 
  2). 设置两个前后相邻的指针p,q. 将p所指向的节点作为q指向节点的后继 
  3). 重复2),直到q为空 
  4). 调整链表头和链表尾 
示例:以逆序A->B->C->D为例,图示如下 

实现及测试代码如下:
#include <stdio.h>  
#include <stdlib.h> 

typedef struct tagListNode{  
	int data;  
	struct tagListNode* next;  
}ListNode, *List;

void PrintList(List head);  
List ReverseList(List head);  

int main()  
{  
	//分配链表头结点  
	ListNode *head;  
	head = (ListNode*)malloc(sizeof(ListNode));  
	head->next = NULL;  
	head->data = -1;  

	//将[1,10]加入链表  
	int i;  
	ListNode *p, *q;  
	p = head;  
	for(int i = 1; i <= 10; i++)  
	{  
		q = (ListNode *)malloc(sizeof(ListNode));  
		q->data = i;  
		q->next = NULL;  
		p->next = q;  
		p = q;          
	}  

	PrintList(head);           /*输出原始链表*/  
	head = ReverseList(head);  /*逆序链表*/  
	PrintList(head);           /*输出逆序后的链表*/  
	return 0;  
} 

List ReverseList(List head)  
{  
	if(head->next == NULL || head->next->next == NULL)    
	{  
		return head;   /*链表为空或只有一个元素则直接返回*/  
	}  

	ListNode *t = NULL,  
		*p = head->next,  
		*q = head->next->next;  
	while(q != NULL)  
	{          
		t = q->next;  
		q->next = p;  
		p = q;  
		q = t;  
	}  

	/*此时q指向原始链表最后一个元素,也是逆转后的链表的表头元素*/  
	head->next->next = NULL;  /*设置链表尾*/  
	head->next = p;           /*调整链表头*/  
	return head;  
} 

void PrintList(List head)  
{  
	ListNode* p = head->next;  
	while(p != NULL)  
	{  
		printf("%d ", p->data);  
		p = p->next;  
	}  
	printf("\n");  
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值