有关差分数组知识讲解这篇博文讲得很好:差分数组
今天刷题碰到一个差分数组的应用题: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数组是长度加一了的,“复原”之后应该去掉最后一个,使得一一对应关系