将一个单链表逆序struct test{int number;double score;test* next;}void

学习 时间:2026-04-09 01:19:08 阅读:4373
将一个单链表逆序struct test{int number;double score;test* next;}void reverse(test*& head){test* pe = head;test* ps = head->next;while(ps = NULL){pe->next = ps->next;ps->next = head;head = ps;ps = pe->next;}}

最佳回答

高大的灰狼

跳跃的睫毛

2026-04-09 01:19:08

数据结构就不用讲了吧。。。下面的函数体是这样:pe指向链表头ps指向链表头的下一个节点原链表头的下一结点不空时{原链表头的下一节点 指向 ps的下一结点ps的下一结点指向现链表头链表头指向psps指向原链表头的下一结点}循环中的四步完成了把原链表头的下一个节点移到链表头的动作,重复到原链表头为链表尾为止。这样就完成了链表的倒序 再问: test* pe = head; test* ps = head->next; //ps=pe->next了么 pe->next = ps->next; //ps=ps->next了么 就这里看不懂, 我觉得直接写循环 head->next->next=head; head=head->next; 不就行了么,怎么那么麻烦 再答: head->next->next=head; head=head->next; 这样的话有一个问题,假如head是节点1,head->next节点是2, 那么第一句执行完了以后,节点2的next指向1; head指向2; 下一循环, 2的下一节点(1)的下一结点(2) 指向头(2)这样就有问题了

最新回答共有2条回答

  • 震动的路灯
    回复
    2026-04-09 01:19:08

    数据结构就不用讲了吧。。。下面的函数体是这样:pe指向链表头ps指向链表头的下一个节点原链表头的下一结点不空时{原链表头的下一节点 指向 ps的下一结点ps的下一结点指向现链表头链表头指向psps指向原链表头的下一结点}循环中的四步完成了把原链表头的下一个节点移到链表头的动作,重复到原链表头为链表尾为止。这样就完成了链表的倒序 再问: test* pe = head; test* ps = head->next; //ps=pe->next了么 pe->next = ps->next; //ps=ps->next了么 就这里看不懂, 我觉得直接写循环 head->next->next=head; head=head->next; 不就行了么,怎么那么麻烦 再答: head->next->next=head; head=head->next; 这样的话有一个问题,假如head是节点1,head->next节点是2, 那么第一句执行完了以后,节点2的next指向1; head指向2; 下一循环, 2的下一节点(1)的下一结点(2) 指向头(2)这样就有问题了

上一篇 符号不同的两个数是互为相反数是对还错

下一篇 亚马逊森林中的第三小题,灭顶之灾用在这里贴切吗,理由是什么.六年级语文练习册上65页的题,