C语言将一个单链表倒置

Reverse(NODE*head){NODE*p,*q,*head_a;head_a=(NODE*)malloc(sizeof(NODE));q=head_a;p=he... Reverse(NODE *head)
{
NODE *p, *q, *head_a;
head_a = (NODE *)malloc(sizeof(NODE));
q = head_a;
p = head->next;
while (p)
{
head->next = p->next;
p->next = q->next;
q->next = p;
p = head->next;
}
q = head_a->next;
while (q)
{
printf("%d\n", q->data);
q = q->next;
}
//实现将单链表倒置
}
我的这个函数为什么可以运行?倒置倒是成功打印出来,但是打印完后程序的崩了。求高手解答
展开
 我来答
溪贝0号123
2020-03-17 · TA获得超过426个赞
知道答主
回答量:228
采纳率:100%
帮助的人:5.5万
展开全部

扣着的是头节点(头子)

车是首节点(首子)

马是次节点(次子)

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

根据步骤写程序的伪算法(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:香头跟着铁头

}

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

kaixingui2012
推荐于2017-09-12 · TA获得超过4.2万个赞
知道大有可为答主
回答量:1.4万
采纳率:81%
帮助的人:6250万
展开全部
		q = head_a;
p = head->next;
q->next=NULL; //加在这里
while (p)
{
head->next = p->next;
p->next = q->next;
q->next = p;
p = head->next;
}
追问
不对吧?我的q指针没有移动过,这样一来q后面的地址我就找不到了
追答
已改了,你没有注意到,再粘一次
q = head_a;
p = head->next;
q->next=NULL; //加在这里!!!不然q->next的首值是个不确定值
while (p)
{
    head->next = p->next;
    p->next = q->next;
    q->next = p;
    p = head->next;
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式