反转单链表 (三种方法整理)
Posted 「已注销」
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了反转单链表 (三种方法整理)相关的知识,希望对你有一定的参考价值。
题目:反转单链表
输入一个链表,反转链表后,输出链表的所有元素。
据找工作的师兄说,反转单链表基本各个公司面试都会有,整理出一些写的比较好的code,供我等小白们学习。
方法一
- 常规思路,简洁,清晰,我觉得写得蛮好的。
思路就是: 从原链表的头部一个一个取节点并插入到新链表的头部
/*
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; )//p为工作指针
ListNode* tmp = p -> next;//temp保存下一个结点
p -> next = newh;
newh = p;
p = tmp;
return newh;
;
- 这是我一开始写得,留着对比用,衬托,哈哈哈
思路一样,但是感觉没第一个写得简洁,但是我的绝对最好理解哈
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;
;
方法三
第三种方法跟第二种方法差不多,第二种方法是将后面的结点向前移动到头结点的后面,第三种方法是将前面的结点移动到原来的最后一个结点的后面,思路跟第二种方法差不多,就不贴代码了。
还想整理一些写得好的,欢迎留言补充
未完待续。。。。。。。。。。。。。。。。。。。
以上是关于反转单链表 (三种方法整理)的主要内容,如果未能解决你的问题,请参考以下文章