| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2162 人关注过本帖
标题:huffman编码问题
只看楼主 加入收藏
yangcaifei
Rank: 4
来 自:陕西
等 级:业余侠客
威 望:2
帖 子:127
专家分:216
注 册:2014-11-3
结帖率:84%
收藏
已结贴  问题点数:100 回复次数:7 
huffman编码问题
//我是用最小堆实现的,以下是建立Huffman树的算法
struct HuffmanNode
{
    int data;
    HuffmanNode *leftChild,*rightChild;
    HuffmanNode():leftChild(NULL),rightChild(NULL){}
    HuffmanNode(int value):data(value),leftChild(NULL),rightChild(NULL){}
    bool operator<=(HuffmanNode& R){return data <= R.data;}
    bool operator>(HuffmanNode& R){return data > R.data;}
    bool operator>=(HuffmanNode& R){return data >= R.data;}
};

void mergeTree(HuffmanNode& bt1,HuffmanNode& bt2,HuffmanNode*& parent)//合并
{
    parent = new HuffmanNode;
    parent->leftChild = &bt1;
    parent->rightChild = &bt2;
    parent->data = bt1.data+bt2.data;
}

HuffmanNode*& HuffmanTree(int value[],int n)
{
    MinHeap<HuffmanNode> min_heap;
    HuffmanNode first,second,*parent;

    for(int i=0;i<n;i++){
        HuffmanNode temp = HuffmanNode(value[i]);
        min_heap.Insert(temp);
    }
    for(int i=0;i<n-1;i++){
        min_heap.Remove(first);
        min_heap.Remove(second);
        mergeTree(first,second,parent);
        min_heap.Insert(*parent);
    }
    return parent;
}

//运行时程序出错
搜索更多相关主题的帖子: return 
2016-02-18 18:16
yangcaifei
Rank: 4
来 自:陕西
等 级:业余侠客
威 望:2
帖 子:127
专家分:216
注 册:2014-11-3
收藏
得分:0 
图片附件: 游客没有浏览图片的权限,请 登录注册
2016-02-18 18:18
yangcaifei
Rank: 4
来 自:陕西
等 级:业余侠客
威 望:2
帖 子:127
专家分:216
注 册:2014-11-3
收藏
得分:0 

Huffman.zip (1.69 KB)
2016-02-18 18:30
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:34 
到底有没有写Remove子函数?
2016-02-18 22:13
yangcaifei
Rank: 4
来 自:陕西
等 级:业余侠客
威 望:2
帖 子:127
专家分:216
注 册:2014-11-3
收藏
得分:0 
回复 4楼 yangfrancis
最小堆都实现了,确定没有问题!
2016-02-18 22:44
wmf2014
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:216
帖 子:2039
专家分:11273
注 册:2014-12-6
收藏
得分:34 
从错误提示上看,是指针溢出,导致非法内存操作。

能编个毛线衣吗?
2016-02-20 12:19
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:0 
把mergeTree的第三个参数去掉,改为返回值传递出去试试
2016-02-21 21:53
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:34 
程序代码:
    HuffmanNode & operator=(const HuffmanNode &h)
    {
        data = h.data;
        leftChild = h.leftChild;
        rightChild = h.rightChild;
        return *this;
    }


[fly]存在即是合理[/fly]
2016-02-22 17:19
快速回复:huffman编码问题
数据加载中...
 
   



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

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