单链表反转(三种方法总结)
2017-10-23 16:12
218 查看
题目:输入一个链表,反转链表后,输出链表的所有元素。
方法一:
思路:从原链表的头部一个一个取节点并插入到新链表的头部
(1)
struct ListNode{
int val;
struct ListNode *next;
ListNode(int x):val(x),next(NULL){}
};
class Solution{
public:
ListNode* ReverseList(ListNode*pHead){
ListNode* newh=NULL;
for(ListNode* p=pHead;p;)
{
ListNode* tmp=p->next;
p->next=newh;
newh=p;
p=tmp;
}
return newh;
}
};(2)
class Solution {
public:
ListNode* ReverseList(ListNode* pHead) {
if(pHead == NULL)
return pHead;
ListNode *res,*cur,*next;
res = new ListNode(-1);
cur = pHead;
next = cur->next;
while(cur != NULL)
{
ListNode *first = res->next;
cur->next = first;
res->next = cur;
cur = next;
next = next->next;
}
return res->next;
}
};方法二:
思路:每次都将原第一个结点之后的那个结点放在新的表头后面。
比如1,2,3,4,5
第一次:把第一个结点1后边的结点2放到新表头后面,变成2,1,3,4,5
第二次:把第一个结点1后边的结点3放到新表头后面,变成3,2,1,4,5
……
直到: 第一个结点1,后边没有结点为止。
代码如下:
class Solution {
public:
ListNode* ReverseList(ListNode* pHead) {
if(pHead == NULL)
return pHead;
ListNode *res,*first,*temp;
res = new ListNode(-1);
res->next = pHead;
first = res->next; //first 始终为第一个结点,不断后移
while(first->next!=NULL) //temp为待前差的
{
temp = first->next;
first->next = temp->next;
temp->next = res->next;
res->next = temp;
}
return res->next;
}
};方法三
第三种方法跟第二种方法差不多,第二种方法是将后面的结点向前移动到头结点的后面,第三种方法是将前面的结点移动到原来的最后一个结点的后面,思路跟第二种方法差不多,就不贴代码了。
方法一:
思路:从原链表的头部一个一个取节点并插入到新链表的头部
(1)
struct ListNode{
int val;
struct ListNode *next;
ListNode(int x):val(x),next(NULL){}
};
class Solution{
public:
ListNode* ReverseList(ListNode*pHead){
ListNode* newh=NULL;
for(ListNode* p=pHead;p;)
{
ListNode* tmp=p->next;
p->next=newh;
newh=p;
p=tmp;
}
return newh;
}
};(2)
class Solution {
public:
ListNode* ReverseList(ListNode* pHead) {
if(pHead == NULL)
return pHead;
ListNode *res,*cur,*next;
res = new ListNode(-1);
cur = pHead;
next = cur->next;
while(cur != NULL)
{
ListNode *first = res->next;
cur->next = first;
res->next = cur;
cur = next;
next = next->next;
}
return res->next;
}
};方法二:
思路:每次都将原第一个结点之后的那个结点放在新的表头后面。
比如1,2,3,4,5
第一次:把第一个结点1后边的结点2放到新表头后面,变成2,1,3,4,5
第二次:把第一个结点1后边的结点3放到新表头后面,变成3,2,1,4,5
……
直到: 第一个结点1,后边没有结点为止。
代码如下:
class Solution {
public:
ListNode* ReverseList(ListNode* pHead) {
if(pHead == NULL)
return pHead;
ListNode *res,*first,*temp;
res = new ListNode(-1);
res->next = pHead;
first = res->next; //first 始终为第一个结点,不断后移
while(first->next!=NULL) //temp为待前差的
{
temp = first->next;
first->next = temp->next;
temp->next = res->next;
res->next = temp;
}
return res->next;
}
};方法三
第三种方法跟第二种方法差不多,第二种方法是将后面的结点向前移动到头结点的后面,第三种方法是将前面的结点移动到原来的最后一个结点的后面,思路跟第二种方法差不多,就不贴代码了。
相关文章推荐
- 单链表反转(三种方法总结)
- 单链表反转(三种方法总结)
- 单链表反转(三种方法总结)
- 单链表反转(三种方法总结)
- 单链表反转(三种方法总结)
- 单链表反转(三种方法总结)
- 单链表反转(三种方法总结)
- 反转单链表 (三种方法整理)
- 不带头结点的单链表反转 三种不同方法实现
- 【总结】逆置双向链表的三种方法
- 【总结】逆置双向链表的三种方法
- 单链表反转的三种方法
- 字符串反转-基于Python的6种方法比较(最全总结版本!)
- 总结:MySQL备份与恢复的三种方法
- jsp页面中插入css样式的三种方法总结
- 链表翻转的是三种方法
- 设计模式之三种工厂模式总结(简单工厂、工厂方法、抽象工厂)
- 总结--获取实例的三种方法(单例,threadlocal,内部类)
- VC中调用其它程序的三种方法总结
- css清除float浮动的三种方法总结