zoukankan      html  css  js  c++  java
  • 单链表的逆置(头插法,就地逆转)

    1.头插法,将链表中的每个元素都插到链表头部,进行逆转。

    void reverse1(Node*head)
    {//头插法逆转单链表
        Node*p,*q;
        p=head->next;
        head->next=NULL;
        while(p)
        {
            q=p;
            p=p->next;
            q->next=head->next;
            head->next=q;
        }
    } 

    2.就地逆置,将链表中的指针指向改变,最后将head指向链表最后一个元素(逆置后的第一个)。

    void reverse2(Node*head)
    {//就地逆转法
        Node *p, *s, *t;
        p = head;  // p开始指向头结点的
        s = p->next; // s最开始是指向第一个节点的
      
        while ( s->next != null )  // 没有到最后一个节点就继续
        {
            t = s->next; // 用t指向s后面的一个节点
            s->next = p; // 把s指向的那个节点想在转换成指向它前面的那个节点,这个时候就实现了逆序,而且是就地逆序
            p = s; // p向后移动到s的位置
            s = t; // s向后移动到t的位置,这时候完成了第一步的置序,后面继续重复之前的动作就OK了
      }
         head->next = null; 
          head->next = s;
    }
  • 相关阅读:
    Django 前后端数据传输、ajax、分页器
    项目分层
    The Jaisalmer Desert Festival 2017/2/9
    Slacklining 2017/2/7
    Slacklining 2017/2/6
    SnowKiting 2017/1/24
    ADO1
    SnowKiting
    CSS-学习笔记六
    D Vitamin
  • 原文地址:https://www.cnblogs.com/didiaoxiaoguai/p/10464392.html
Copyright © 2011-2022 走看看