标题:如何实现懒惰删除
只看楼主
hawick
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2009-9-21
 问题点数:0 回复次数:1 
如何实现懒惰删除
为删除一个元素,只标记上该元素被删除(使用一个附加的bit域),表中删除元素和非被删除元素的个数作为数据结构的一部分被保留。如果被删除元素和非被删除元素的个数一样多,遍历整个链表,对所有被标记的节点执行标准的删除算法。
谁能帮写个参考例程呢?谢谢。
搜索更多相关主题的帖子: 删除 懒惰 
2009-10-10 13:34
y2k_connect
Rank: 2
等 级:论坛游民
威 望:1
帖 子:15
专家分:61
注 册:2009-10-4
得分: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



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




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

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