算法学习-单链表反转

单链表的反转是一道很基本的算法题,一般可以想到以下三种方法:

  • 方法1:将单链表储存为数组,然后按照数组的索引逆序进行反转。
  • 方法2:使用三个指针遍历单链表,逐个节点进行反转。
  • 方法3:从第2个节点到第N个节点,依次逐节点插入到第1个节点(head节点)之后,表的最后将第一个节点挪到新表尾。

第一种不太可取,主要看下第二种和第三种的实现。

方法二:

Node* ReverseList(Node *head)  
{  
    Node *p1,*p2,*p3;  
    if(head==NULL||*head==NULL)  
    {
        return head; 
    } 
    p1=head;  
    p2=p1->next;  
    while(p2)             //注意条件  
    {  
        p3=p2->next;       //要改变p2->next的指针,所以必须先保留p2->next           
        p2->next=p1;  
        p1=p2;            //循环往后  
        p2=p3;  
    }  
    head->next=NULL;   //原先的head已经变成tail,别忘了置空,只有到这步才能置空  
    *head=p1;  
    return head;  
} 

方法三:

Node* ReverseList(Node* head)   
{   
    Node *p,*q;    
    p=head->next;   
    while(p->next!=NULL)      //在这个循环过程中p所指的元素一直是不变的  
    {  
        q=p->next;   
        p->next=q->next;   
        q->next=head->next;   
        head->next=q;   
    }    
    p->next=head;            //相当于成环   
    head=p->next->next;       //新head变为原head的next   
    p->next->next=NULL;     //断掉环   
    return head;     
} 
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 5,138评论 0 12
  • 大学的时候不好好学习,老师在讲台上讲课,自己在以为老师看不到的座位看小说,现在用到了老师讲的知识,只能自己看书查资...
    和珏猫阅读 1,470评论 1 3
  • 最近想回过头来看看以前写的一些代码,做的一些项目,可叹为何刚进大学的时候不知道要养成写博客的好习惯。现在好多东西都...
    寻找时光机阅读 1,754评论 0 2
  • 01 人们总说,当你努力完善自己的时候,让自己成为那个值得被爱的人的时候,爱人也自然会有。我们会对自己的未来做个规...
    芒影阅读 787评论 1 15
  • 我出生在80末年,没错,在这个00后已经升级做奶爸、奶妈的时代,即将迈入30这个门槛的我依旧单着~和其他单身狗不...
    Love奥利奥阅读 482评论 1 1