首页 > 代码库 > 树状数组的特殊形式
树状数组的特殊形式
1 //用树状数组维护前i项最值 2 3 map<int,int> m;//用map可以突破下标过大导致的空间限制 4 5 int lowbit(int x) 6 { 7 return x&-x; 8 } 9 10 void upd(int idx,int val) 11 { 12 while(idx<maxn) 13 { 14 m[idx]=max(val,m[idx]); 15 idx+=lowbit(idx); 16 } 17 } 18 19 int query(int idx) 20 { 21 int ans=0; 22 while(idx>0) 23 { 24 ans=max(ans,m[idx]); 25 idx-=(idx&(-idx)); 26 } 27 return ans; 28 }
算是这场CF的最大收获吧
树状数组的特殊形式
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。