链表反转
2016-09-08 11:08
148 查看
1、定义节点
typedef struct Node
{
int data;
struct Node* pNext;
}NODE, *PNODE;
2、创建链表
PNODE create_list()
{
int len;
int i;
int val;
PNODE pHead = (PNODE)malloc(sizeof(NODE));
if(pHead == NULL)
return 0;
PNODE pTail = pHead;
pTail->pNext = NULL;
cout<<"请输入您要生成的链表的个数:";
cin>>len;
for(i = 0; i < len; i++)
{
cout<<"请输入第"<<i+1<<"个节点的值:";
cin>>val;
PNODE pNew = (PNODE)malloc(sizeof(NODE));
pNew->data = val;
pTail->pNext = pNew;
pNew->pNext = NULL;
pTail = pNew;
}
return pHead;
}3、遍历链表
void traverse_list(PNODE pHead)
{
PNODE p = pHead->pNext;
while(p != NULL)
{
cout<<p->data<<' ';
p = p->pNext;
}
}
4、反转链表
PNODE ReverseList(PNODE pHead)
{
// 如果链表为空或只有一个结点,无需反转,直接返回原链表头指针
if(pHead == NULL || pHead->pNext == NULL)
return pHead;
PNODE pReversedHead = NULL; //反转后链表的头结点,初始化为NULL
PNODE pCurrent = pHead; //定义pCurrent指向链表中头结点
while(pCurrent != NULL)
{
PNODE pTemp = pCurrent;
pCurrent = pCurrent->pNext;
pTemp->pNext = pReversedHead; //把pRverseHead定位为反转后链表的头结点,
pReversedHead = pTemp; //把头结点放在ptemp位置.
int main()
{
PNODE pHead = NULL;
pHead = create_list();
traverse_list(pHead);
cout<<endl;
PNODE p = NULL;
p = ReverseList(pHead->pNext);
traverse1_list(p);
cout<<endl;
return 0;
}
6、运行结果
typedef struct Node
{
int data;
struct Node* pNext;
}NODE, *PNODE;
2、创建链表
PNODE create_list()
{
int len;
int i;
int val;
PNODE pHead = (PNODE)malloc(sizeof(NODE));
if(pHead == NULL)
return 0;
PNODE pTail = pHead;
pTail->pNext = NULL;
cout<<"请输入您要生成的链表的个数:";
cin>>len;
for(i = 0; i < len; i++)
{
cout<<"请输入第"<<i+1<<"个节点的值:";
cin>>val;
PNODE pNew = (PNODE)malloc(sizeof(NODE));
pNew->data = val;
pTail->pNext = pNew;
pNew->pNext = NULL;
pTail = pNew;
}
return pHead;
}3、遍历链表
void traverse_list(PNODE pHead)
{
PNODE p = pHead->pNext;
while(p != NULL)
{
cout<<p->data<<' ';
p = p->pNext;
}
}
void traverse1_list(PNODE pHead) { PNODE p = pHead; while(p != NULL) { cout<<p->data<<' '; p = p->pNext; } }
4、反转链表
PNODE ReverseList(PNODE pHead)
{
// 如果链表为空或只有一个结点,无需反转,直接返回原链表头指针
if(pHead == NULL || pHead->pNext == NULL)
return pHead;
PNODE pReversedHead = NULL; //反转后链表的头结点,初始化为NULL
PNODE pCurrent = pHead; //定义pCurrent指向链表中头结点
while(pCurrent != NULL)
{
PNODE pTemp = pCurrent;
pCurrent = pCurrent->pNext;
pTemp->pNext = pReversedHead; //把pRverseHead定位为反转后链表的头结点,
pReversedHead = pTemp; //把头结点放在ptemp位置.
} return pReversedHead; }5、main
int main()
{
PNODE pHead = NULL;
pHead = create_list();
traverse_list(pHead);
cout<<endl;
PNODE p = NULL;
p = ReverseList(pHead->pNext);
traverse1_list(p);
cout<<endl;
return 0;
}
6、运行结果
相关文章推荐
- 面试题14:反转链表
- 单链表创建插入删除打印反转
- 反转单向链表(每日一道算法题)
- 链表常用操作 (定义,创建,反转,合并,交叉)
- 剑指offer--16.反转链表
- 算法题练习系列之(十八): 反转链表
- 反转单向链表(reverse a singly linked list)(单个反转) [# 7]
- 反转链表练习
- 反转链表:迭代和递归的实现
- 链表面试题(一):反转链表的算法实现
- 15 反转链表
- 反转链表
- 自己写的 关于链表的反转!欢迎给予意见!2012-2-18--2012-2-19
- 数据结构笔记--反转链表分析
- 反转链表(递归与非递归)
- 反转链表
- 题目1518:反转链表
- 链表反转和找出链表中间节点
- 单链表反转
- java 实现单链表反转