1 Star 0 Fork 2

刘勇强 / interview_internal_reference

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
1.1.1 如何实现一个高效的单向链表逆序输出?.md 921 Bytes
一键复制 编辑 原始数据 按行查看 历史
3168047058 提交于 2019-09-24 11:35 . add file
问题:如何实现一个高效的单向链表逆序输出?
出题人:阿里巴巴出题专家:昀龙/阿里云弹性人工智能负责人
参考答案:下面是其中一种写法,也可以有不同的写法,比如递归等。供参考。
typedef struct node{
    int           data;
    struct node*  next;
    node(int d):data(d), next(NULL){}
}node;

void reverse(node* head)
{
    if(NULL == head || NULL == head->next){
        return;
    }
    
    node* prev=NULL;
    node* pcur=head->next;
    node* next;
    
    while(pcur!=NULL){
        if(pcur->next==NULL){
            pcur->next=prev;
            break;
        }
        next=pcur->next;
        pcur->next=prev;
        prev=pcur;
        pcur=next;
    }
    
    head->next=pcur;
    node*tmp=head->next;
    while(tmp!=NULL){
        cout<<tmp->data<<"\t";
        tmp=tmp->next;
    }
}
C++
1
https://gitee.com/LiuYongQiang0816/interview_internal_reference.git
git@gitee.com:LiuYongQiang0816/interview_internal_reference.git
LiuYongQiang0816
interview_internal_reference
interview_internal_reference
master

搜索帮助