②不过区间在增加时,每次并不是增加一个长度,而是基于倍增思想,用二进制右移,每次增加2^i个长度 ,最多增加logn次
这样预处理了所有2的幂次的小区间的最值
关于倍增法链接
查询:
③对于每个区间...,分成两段长度为的区间,再取个最值(这里的两个区间是可以有交集的,因为重复区间并不影响最值)
比如3,4,6,5,3一种分成3,4,6和6,5,3,另一种分成3,4,6和5,3,最大值都是6,没影响。...)预处理,O(1)查询最值 但不支持修改
预处理时间复杂度O(nlogn),查询时间O(1)。...x=int (log(y-z+1)/log(2));//注意y-z要加一才为区间长度
return min(map[z][x],map[y-(1<<x)+1][x]);//分别以左右两个端点为基础...,向区间内跳1<<x的最
//大值;
}
int main()
{
scanf("%d",&N);//输入数据总数
scanf("%d",&K);//输入询问次数k
for(