将一个单链表逆序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;
}
}
1个回答 分类:综合 2014-11-14

问题解答:

我来补答
数据结构就不用讲了吧...
下面的函数体是这样:
pe指向链表头
ps指向链表头的下一个节点
原链表头的下一结点不空时{
原链表头的下一节点 指向 ps的下一结点
ps的下一结点指向现链表头
链表头指向ps
ps指向原链表头的下一结点
}
循环中的四步完成了把原链表头的下一个节点移到链表头的动作,重复到原链表头为链表尾为止.这样就完成了链表的倒序
再问: 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)这样就有问题了
 
 
展开全文阅读
剩余:2000
上一页:算数过程
下一页:enjoy的反义词