美文网首页程序员
算法学习-单链表反转

算法学习-单链表反转

作者: vincentgemini | 来源:发表于2017-11-16 23:10 被阅读0次

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

  • 方法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;     
} 

相关文章

  • 单链表反转问题

    基本问题 如何将单链表反转? 单链表结构定义 算法实现 进阶问题 如何将单链表在指定区间内进行反转? 问题分析 这...

  • 单链表

    单链表一些相关的算法集锦,单链表的算法可以提高逻辑能力。 反转链表 最基本的链表的题目,很简单的迭代操作,需要注意...

  • Algorithm小白入门 -- 单链表

    单链表递归反转链表k个一组反转链表回文链表 1. 递归反转链表 单链表节点的结构如下: 1.1 递归反转整个单链表...

  • 算法学习-单链表反转

    单链表的反转是一道很基本的算法题,一般可以想到以下三种方法: 方法1:将单链表储存为数组,然后按照数组的索引逆序进...

  • 数据结构 - 单向链表及相关算法

    单向链表 链表常见算法 链表反转

  • 单链表反转

    单链表 单链表反转 递归方法

  • Java、Python3 实战 LeetCode 高频面试之单链

    单链表反转 单链表反转这道题可谓是链表里面的高频问题了,差不多可以说只要被问到链表,就会问单链表反转。 今天我们就...

  • 单链表反转

    单链表反转 很多时候工作和面试的时候都会遇到类似的单链表反转的情况,今天就参考写了一个,类似数据结构和算法的知识,...

  • 链表简单算法相关练习

    单链表反转: 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 迭代方式实现: 复杂度分析: 时...

  • 链表算法之-单链表反转

    算法解析:创建pre节点和temp节点,让temp节点记录当前p几点的下一个节点,然后将当前节点指向下一节点的键断...

网友评论

    本文标题:算法学习-单链表反转

    本文链接:https://www.haomeiwen.com/subject/vcirvxtx.html