单链表的逆置(头插法,就地逆转)

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;
}

 

转载于:https://www.cnblogs.com/didiaoxiaoguai/p/10464392.html

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值