标题:链串,2个串合成一个串时候的操作疑问........相信是大家共同的问题
只看楼主
maiiho
Rank: 1
等 级:新手上路
帖 子:94
专家分:7
注 册:2008-7-17
结帖率:50%
 问题点数:0 回复次数:1 
链串,2个串合成一个串时候的操作疑问........相信是大家共同的问题
typedef struct node
{
   struct node *next;
}LiString;
void concat(LiString *s1,LiString *s2,LiString *&s)
{
   node *p,*q,*r;   //1.为什么要声明为node结构体?而不是LiString类型?   
   s=(LiString *)malloc(sizeof(LiString));
   //2.s分配好内存之后,与未分配内存的时候有什么区别?
   s->next=null;
   r=s;   //3.s已经分配好了内存,而r没有,并且s是LiString类型指针,而r是结构体指针,怎么能赋值?
   while(p!=null)
{
   q=(LiString *)malloc(sizeof(LiString));
   q->data=p->data;
   r->next=q;
   r=q;      //4.r=q,是怎么样的?   p=p->next;
}
----------------------------------------------------------------------------------------------------
望各位JJMM不理赐教!
搜索更多相关主题的帖子: 疑问 
2008-11-19 22:08
SnakeEater
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2008-11-25
得分:0 
1.不清楚,感觉应该是ListString类型,要不然是struct node。
2.未分配内存时,s指针悬空,没有指向一个ListString类型的单元,所以不可以使用s操作ListString类型的单元(如s->next)。
3.typedef struct node
{
   struct node *next;
}LiString;
这样的话,用struct node定义和LiString定义是等效的啦
4.r=q 尾插法,保证r始终指向这个新串的尾节点
我也是新手,个人见解,呵呵
大家多多交流
2008-11-25 18:21



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




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

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