从尾到头打印链表,不允许逆置原链表


方法1:用栈实现,从第一个节点开始逐步向后,然后把节点的指针(地址)依次推入栈中,当全部遍历结束后,从栈顶开始依次取出内容,并打印数据。由于后来的节点地址在栈的上方,所以打印顺序是从尾打印的。

voidprint(Node *list)

{
       stack<Node*>node;
       Node*p=list;
       while(p!=NULL)
       {
              node.push(p);
              p=p->next;
       }
       while(!node.empty())//若栈为空返回true,不为空返回false 
       {
              p=node.top();
              cout<<p->data<<",";
              node.pop();
             
       }
}

方法2:用递归实现;实现代码简洁,但是当链表较长的时候,会导致递归调用的层次很深,有可能导致函数调用栈溢出。用栈性能会更好,谨慎使用递归。

void print(Node *list)
{
       Node*p=list;
       if(p!=NULL)
       {
              if(p->next!=NULL)
              {
                     print(p->next);
              }
              cout<<p->data<<",";
       }
 
}
 


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值