将一个单链表逆序struct test{int number;double score;test* next;}void
将一个单链表逆序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;}}
最佳回答
数据结构就不用讲了吧。。。下面的函数体是这样: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)这样就有问题了
热门文章
- 康达学院专转本五年制
- 高考一个考场分ab卷吗
- not only but also用法
- 某物体做自由落体运动,从释放开始计时,则物体在前2s内的平均速度为______m/s,物体下落2m时的速度大小为______m/s.
- 三角函数公式大全表格
- 地理中考必背知识点2022
- 2013-2014学年小学六年级科学上学期期末考试试卷及答案
- 人教版2014-2015学年小学五年级英语第二学期期中教学质量检测试卷及答案
- 【Linux驱动开发】设备树详解(二)设备树语法详解
- 别跟客户扯细节
- 在别的城市买房子能落户吗
- 卖房前要把装修贷还完吗
- 高中政治教学提高教学效果的方法探究
- “互联网+”背景下的初中英语课堂教学改革与创新策略研究
- 2022年终止合同范本
- 租房合同范本范文
- 如何挑选土豆
- 如何挑选土鸡
