链表逆序
2014-11-27 17:08
197 查看
设链表节点为
[cpp]
view plaincopy
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为例,图示如下
实现及测试代码如下:
[cpp]
view plaincopy
#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");
}
[cpp]
view plaincopy
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为例,图示如下
实现及测试代码如下:
[cpp]
view plaincopy
#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");
}
相关文章推荐
- 剑指offer--指定链表逆序打印
- 数据结构——20 单链表逆序
- 将一个链表逆序并输出
- 有一个带头结点的单链表L={a1,b1,a2,b2,...,an,bn},设计一个算法将其拆分成两个带头结点的单链表A和B,正序链表A={a1,a2,a3...,an},逆序链表B={bn,bn-1,
- 数据结构之 线性表 逆序简历链表
- 单链表逆序的递归与非递归算法
- 链表的建立、输出、逆序
- SDUT 2117-数据结构实验之链表二:逆序建立链表
- java 链表逆序
- 华为机试—逆序链表输出
- [LeetCode]2. Add Two Numbers用链表逆序存储的两个数相加
- 如何逆序输出一个链表的节点内容
- ms的将链表逆序的笔试题
- 单链表的冒泡排序以及逆序(交换指针法)
- 很简单的链表逆序C代码,笔试常考
- C语言经典算法100例-073-链表逆序插入节点
- c++实现单链表逆序
- 最简洁的单向链表逆序
- 链表逆序(递归实现和非递归实现)
- 单链表的逆序(反转)