设为首页收藏本站

新微赢技术网

 找回密码
 注册
搜索
热搜: 回贴
查看: 1826|回复: 1
打印 上一主题 下一主题

链表问题...

[复制链接]
跳转到指定楼层
1#
发表于 2009-11-3 03:51:34 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
请问:
我已有一条链,p为结点
但我想新建另一链,t为结点...可就不能把t=p那样建,而是要把p里的元素一个个赋值给t才行.....
那是什么问题呢??
还有,假如我只是定义个结点,而不用new来建...,再用t=p(如果可以的话)那可以吗,那样有什么区别呢?
2#
发表于 2009-11-3 03:51:35 | 只看该作者
假设你的节点类型名为Node吧
Node* t=new Node;
t=p;首先你也知道,这就是让这两个节点都指向p指向的位置,内存显然泄漏。
如果不用new,你是想说Node *t;t=p;是这样吗?
那虽然不会内存泄露,但是问题在于他一样也是指向同一位置,没有复制另外一份。
如果你是说定义一个节点,那你是说Node t;t=p;吗?
那显然是错误的,cann't conversion 'Node*' to 'Node'.
如果是要再建立一个表,有如下方法复制拷贝:
我想你的原有的链表应该是通过类来实现的吧。
那可以定义一个拷贝构造函数。
比如类名是List;首指针是Node*first;(假设只有这个数据成员)
template<class T>struct Node{Node*next;T info;};
那么这个拷贝构造函数如下:
List(const List&list)
{
bool f=true;//循环第一次
Node*current;
for(Node*l_current=list.first;l_current;)
{
Node* temp=new Node;
temp->info=l_current->info;
temp->next=NULL;
if(f)first=current=temp;
else
{
current->next=temp;
current=current->next;
}
f=false;
l_current=l_current->next;
}
}
如果是想定义函数,相比这个构造函数—>就是需要加些delete,因为拷贝构造函数和析构函数对应,而成员函数就必须要因为构造函数已经分配内存,现在要释放这些后,再重新分配。不然就分配两次,一次析构是不会清楚干净的
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

申请友链|小黑屋|最新主题|手机版|新微赢技术网 ( 苏ICP备08020429号 )  

GMT+8, 2024-11-18 16:26 , Processed in 0.094094 second(s), 9 queries , Gzip On, Memcache On.

Powered by xuexi

© 2001-2013 HaiAn.Com.Cn Inc. 寰耽

快速回复 返回顶部 返回列表