搜索
编程论坛
→
开发语言
→
『 数据结构与算法 』
→ 如何实现懒惰删除
标题:
如何实现懒惰删除
只看楼主
hawick
等 级:
新手上路
帖 子:5
专家分:0
注 册:2009-9-21
楼主
问题点数:0 回复次数:1
如何实现懒惰删除
为删除一个元素,只标记上该元素被删除(使用一个附加的bit域),表中删除元素和非被删除元素的个数作为数据结构的一部分被保留。如果被删除元素和非被删除元素的个数一样多,遍历整个链表,对所有被标记的节点执行标准的删除算法。
谁能帮写个参考例程呢?谢谢。
搜索更多相关主题的帖子:
删除
懒惰
2009-10-10 13:34
y2k_connect
等 级:
论坛游民
威 望:
1
帖 子:15
专家分:61
注 册:2009-10-4
第
2
楼
得分:0
typedef struct nodeDate {
int flag; // 删除标志。0:删除;1:使用中。
... ...
} *Date;
typedef struct node {
Date date;
struct node *next; // 下一个元素。-1:最后一个元素。
} *Node;
void Pack(Node* head) {
Node p, q;
q = *head;
for (p=*head; p->next > 0; p=q->next)
if (! p->date->flag ) {
q->next = p->next;
free(p->date);
free(p);
} else
q = p;
}
2009-10-21 21:18
2
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-288049-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.020792 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved