求解一段C语言代码单链表的逆序输出(数据结构)

void Reversal(Linklist &head){   Linklist p,q;  p=head->next;  head->next=NULL;while(p!=NULL){     q=p->next;     p->next=head->next;     head->next=p;      p=q;     }}我觉得应该可以使单链表逆序输出,为什么主函数中显示不出任何结果。。。

扣着的是头节点(头子)

车是首节点(首子)

马是次节点(次子)

牙签细的是指针指向,香头发黑的是指向,铁头细的是指向。

根据步骤写程序的伪算法(3步4循环,7张图片搞定),如下:


以下是while循环(条件:香头指向不为空)

第一个循环把马弄到车前面,

第二个循环把相弄到马前面

第三个循环把士弄到相前面

........

直到香指向为空后停止循环。

代码如下:只需要一个首结点pHead,就能把链表找到,并倒置。具体代码如下

p香=pHead->pNext;

p铁=p香->pNext;

p香->pNext=NULL;

P香=p铁

while(p香 !=NULL)

{

     p铁=p香->pNext;

     p香->pNext=pHead->pNext;

     pHead->pNext=p香;

     p香=p铁;

}


对照伪算法(三步四循环),和上面的代码是一一对应的:

第一步:香头指向首子,铁头指向次子

第二步:删掉首子指向次子(铁头所指向的那个子)的牙签

第三步:香头跟着铁头

以下循环条件:(条件:香头指向不为空)

{

    循环1:铁头移动到香头的下一个指向

    循环2:香头的下一个指向首子

    循环3:头子的下一个跟着香头

    循环4:香头跟着铁头

}

自己用道具操作几遍,然后把流程背会,以后自己根据流程写代码即可。

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-11-24
void Reversal(Linklist &head){
Linklist p,q;
p=head->next;
head->next = NULL;
while(p!=NULL){
q = p->next; //记录当前位置的下一结点。
p->next = head; //当前位置的下一指针应该指向头,也就是插入到头结点前面。
head = p; //改变头指针变量,指向最新的位置 ,才能完成逆序
p = q; //更新当前位置为下一结点。
}
}本回答被网友采纳
第2个回答  2012-02-10
void Reversal(Linklist &head){
Linklist p,q;
p=head->next;
head->next=NULL; // 此时链接已经断了 下面就不用看了
while(p!=NULL){
q=p->next;
p->next=head->next;
head->next=p;
p=q;
}
}
你没有理解和使用好对于引用与指针
还有对于链表的结构掌握不是太好
引用就是针对原对象来操作的 不要随意的更改你的数据结构
相似回答