| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 305 人关注过本帖
标题:关于c语言链表的一个理解上的问题 ,求指导
只看楼主 加入收藏
努力学习ing
Rank: 1
等 级:新手上路
帖 子:7
专家分:1
注 册:2012-10-15
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:4 
关于c语言链表的一个理解上的问题 ,求指导
我省去了一些代码,这里吧关键代码给上:
struct node *createbackward()
{
    struct node *head,*p,*tail;
    TYPE data;
    printf("请输入一个整数(以0结束):\n");
    readnode(&data);
    head=NULL;tail=NULL;
    while(!endwith(data))
    {
        p=(struct node*)malloc(size);
        p->data=data;
        p->next=NULL;
        if(head=NULL)
        {
            head=p;
        }
        else
            tail->next=p;
        tail=p;
        readnode(&data);
    }
    return head;
}
这是关于用后插法新建链表的部分代码,我有一个问题搞不懂,就是这里面的tail怎么就是指向尾结点啊?是默认的吗?
在线等指导...


[ 本帖最后由 努力学习ing 于 2012-10-17 11:07 编辑 ]
2012-10-17 10:36
pengzhuo2008
Rank: 2
来 自:湖南
等 级:论坛游民
帖 子:29
专家分:68
注 册:2012-9-28
收藏
得分:10 
tail = p
这一句不是很清楚吗?

1+1=2
2012-10-17 10:42
努力学习ing
Rank: 1
等 级:新手上路
帖 子:7
专家分:1
注 册:2012-10-15
收藏
得分:0 
回复 2楼 pengzhuo2008
这一句的前提不是应该tail指向最后一个结点吗?
你可能理解错了,我是想说tail怎么就表示了最后一个结点了.
比如:
while(p->next)
{
     p=p->next;
}
这样不是才能表明P是最后一个结点吗?
怎么tail不需要?
2012-10-17 10:49
pengzhuo2008
Rank: 2
来 自:湖南
等 级:论坛游民
帖 子:29
专家分:68
注 册:2012-9-28
收藏
得分:0 
回复 3楼 努力学习ing
......
你要从整体上看你发的这段代码呀
我的建议就是,直接将这个函数打个断点
你跟踪调试一下,然后你就会很清楚了。
这个比我说啥子都要清楚的
共同学习吧

1+1=2
2012-10-17 11:07
努力学习ing
Rank: 1
等 级:新手上路
帖 子:7
专家分:1
注 册:2012-10-15
收藏
得分:0 
回复 4楼 pengzhuo2008
我 程序还没编完,编好了我试试。谢了,有不懂得还请多指导...
2012-10-17 11:11
快速回复:关于c语言链表的一个理解上的问题 ,求指导
数据加载中...
 
   



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

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