| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 771 人关注过本帖
标题:求解释数据结构链表的一个小问题,感激不尽
只看楼主 加入收藏
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
快速回复:求解释数据结构链表的一个小问题,感激不尽
数据加载中...
 
   



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

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