差分数组的应用——统计频次等

有关差分数组知识讲解这篇博文讲得很好:差分数组

今天刷题碰到一个差分数组的应用题:LeetCode1589

很有意思,仔细读题不难看出,这道题关键是统计每个区间内顶点(下标)出现的频次大小,进行排序。首先想到的是直接依次遍历区间用hash表统计频次,然而这种方法在数据很大的时候必然会超时,这时可以使用差分数组进行统计,从而减少运行时间。

将hash表定义为一个差分数组count,hash表初始值应该全为0,刚好此时对应的差分数组也应该全为0。需要特别注意的: 如果hash表的长度为len,那么相对应的差分数组长度应该为len+1。

接下来就应该是统计频次了,对于每一个区间,此时不再需要遍历,而是只需将左端点对应的count值加一,以及右端点的下一个位置的count值减一即可,最后对count差分数组进行一次遍历即可“复原”hash频次表。具体代码如下:

 vector<int> count(len+1,0);    //差分表长度加一
        for(int i=0;i<requests.size();i++){   //对每个区间
            count[requests[i][0]]++;      //左端点count值加一
            count[requests[i][1]+1]--;    //右端点下一个位置的count值减一
        }
        for(int i=1;i<=len;i++){
            count[i]=count[i]+count[i-1];   //差分数组“复原”频次值
        }
        count.pop_back();   //注意原来的count数组是长度加一了的,“复原”之后应该去掉最后一个,使得一一对应关系
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值