标题:求解释数据结构链表的一个小问题,感激不尽
只看楼主
dengdaisky
Rank: 1
等 级:新手上路
帖 子:28
专家分:0
注 册:2010-4-11
结帖率:54.55%
 问题点数:0 回复次数:3 
求解释数据结构链表的一个小问题,感激不尽
这是问题图:
{
http://www.
}
我想问一下链表插入 ,假设要在a,b两个节点中间插入一个数据域为x的节点,已知p指向数据域为a的节点,s指向数据域为x的节点。
为了插入节点s。就是修改p的指向
书上是这么写的:s->next=p->next; p->next=s;
为什么不是:p->next=s->next呢?   
我想问一下p->next是 图中a的空白还是b?   如果是空白
那为什么删除b点(图二)中 就是只要p->next->next呢? 那应该是b的空白啊,而不是C。但书上为什么是指向C呢,而达到删除b的目的.....
求详解!
搜索更多相关主题的帖子: next 
2013-05-14 13:31
Susake
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:女儿国的隔壁
等 级:贵宾
威 望:23
帖 子:2288
专家分:6481
注 册:2012-12-14
得分:0 
跟着程序在纸上画一遍...
程序代码:
Status listInsert(LinkList L, int i, LElemType e) {
    LNode *p = L, *q;
    int j = 0;
    while(j < i - 1 && p -> next) {
        p = p -> next;
        j++;
    }
    if(j == i - 1) {
        q = (LNode *)malloc(sizeof(LNode));
        if(!q) return OVERFLOW;
        q -> data = e;
        q -> next = p -> next;
        p -> next = q;
        return OK;
    }
    else return ERROR;
}

仰望星空...........不忘初心!
2013-05-17 11:56
ithaibo
Rank: 2
等 级:论坛游民
帖 子:52
专家分:50
注 册:2012-3-30
得分:0 
链表插入结点的关键在于,保证整个链的完整性。由于链表结点不同于顺序表的结点(地址连续),你只能在单链表中插入结点前找到下一结点的地址并保存。建议认真理解单链表的插入。
2013-05-29 15:55
轻微1213
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2013-5-29
得分:0 
p->next中存放的是结构体b的地址。p->next->next = b->next。
2013-05-29 21:40



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-407047-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.191638 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved