使用搜索树的直方图

首先实现一个简单的直方图程序

void main()
{//非负整形的直方图
int n,r;//元素个数n,元素最大值r。
cout<<"Enter number of elements and range"<<endl;
cin>>n>>r;
//生成直方图数组
int *h=new int[r+1];
//将数组h初始化为0
for(int i=0;i<=r;i++)
    h[i]=0;
//输入数据然后计算直方图
for(int i=1;i<=n;i++)
{//假设输入的数据在0至r之间
int key;
cout<<"Enter element"<<i<<endl;
cin>>key;
h[key]++;
}
//输出直方图
cout<<"Distinct elements and frequencies are"<<endl;
for(i=0;i<=r;i++)
    if(h[i]=0)
        cout<<i<<" "<<h[i]<<endl;   
}

代码很简单我就直接照搬书上的注释了。
上述代码的缺点就是当数据不是整形或者数据量很大时就不适用了。

使用搜索树的直方图:
实现原理:我们定义树节点包含的数据位key和key出现的频率初始频率为1,然后将数据一个个插入到树中,插入数据时如果该数据存在则visit该数据并将相应的key的频率加一,如果该数据不存在则直接插入该数据。

void main()
{//非负整形的直方图
int n,r;//元素个数n,元素最大值r。
cout<<"Enter number of elements and range"<<endl;
cin>>n>>r;
//生成直方图数组
int *h=new int[r+1];
//将数组h初始化为0
for(int i=0;i<=r;i++)
    h[i]=0;
//输入数据然后计算直方图
for(int i=1;i<=n;i++)
{//假设输入的数据在0至r之间
int key;
cout<<"Enter element"<<i<<endl;
cin>>key;
h[key]++;
}
//输出直方图
cout<<"Distinct elements and frequencies are"<<endl;
for(i=0;i<=r;i++)
    if(h[i]=0)
        cout<<i<<" "<<h[i]<<endl;   
}

int main()
{//使用搜索树的直方图
int n;
cout<<"Enter number of element"<<endl;
cin>>n;
//输入元素然后插入树
binarySearchTreeWithVisit<int,int>theTree;
for(int i=1;i<=n;i++)
{
    pair<int,int>thePair;
    cout<<"Enter element"<<i<<endl;
    cin>>thePair.first;
    thePair.second=1;//初始频率为1
    three.insert(thePair,add1);//这个代码在搜索树里面已经实现了,第二个参数为一个函数指针指向visit函数,visit函数我们并未实现书上没给
}
cout<<"Distinct elements and frequencies are"<<endl;
thrTree.ascend();//这个函数书上也没给,就是一个输出函数。  
}

书上两个函数没有给出,不过都很简单。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值