码迷,mamicode.com
首页 > 其他好文 > 详细

背包的一些idea

时间:2018-06-01 00:15:16      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:MLOG   二分   原理   树分治   for   之间   不能   区间   dea   

题解:

给出n个物品,每次能使用l-r之间的物品,问能不能表示出k,m次询问

k<=100,m,n=1e5

想了线段树分治 发现是k^2(n+m)logn

claris告诉我可以直接分治

我们对mid-r mid-l分别求一次背包

这样是nklogn的

我们就可以对包含mid的公司做处理

o(k) 查询

for(i=0;i<=k;i++)ans|=f[l][i]&g[r][k-i]

然后就解决了

还有个问题是怎么找对应mid的区间

我的思路是对每层都枚举所有询问暴力二分一下h的后继(把所有区间起点搞出来)

这样是mlog^2 n (虽然不影响)

claris提供了一种mlogn的做法

原理是每个有效点只会进入log次

做法就是每次对不在区间内的扔了 做好的也扔了(不然指数级递增的)

背包的一些idea

标签:MLOG   二分   原理   树分治   for   之间   不能   区间   dea   

原文地址:https://www.cnblogs.com/yinwuxiao/p/9119651.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!