| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1818 人关注过本帖
标题:如何实现懒惰删除
只看楼主 加入收藏
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
快速回复:如何实现懒惰删除
数据加载中...
 
   



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

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