Melancholy(磨懒虫主义)
题目大意:给出n个地点和q个询问。其中每个地点有距离和权值,每个询问给出l,r,k,表示在[l,r]区间内不取最小点的情况下任取k个,求所有情况权值之积之和(n,q<=1e5,k<=6)。
能看出来是区间操作,先考虑树状数组,发现维护比较难。于是用线段树维护。
每个节点记录7个值,分别为minv和不算minv任取1~6个所得值。dalao的正解用了RMQ+容斥,但我都没用。
#include<cstdio>
#include<algorithm>
using namespace std;
#define N 100050
#define ui unsigned int
int n,Q;
struct pla
{
int d,v;
}p[N];
bool cmp(pla a,pla b)
{
return a.d<b.d;
}
struct segtree
{
ui mn;
ui v[];
}tr[*N];
segtree operator * (segtree s0,segtree s1)
{
segtree ret;
for(int i=;i<=;i++)
{
ret.v[i]=s0.v[i]+s1.v[i];
for(int j=;j<i;j++)ret.v[i]+=s0.v[j]*s1.v[i-j];
}
ret.mn = min(s0.mn,s1.mn);
ui mx = max(s0.mn,s1.mn);
for(int i=;i>=;i--)
{
ret.v[i]+=ret.v[i-]*mx;
}
ret.v[]+=mx;
return ret;
}
void update(int u)
{
tr[u] = tr[u<<] * tr[u<<|];
}
void build(int l,int r,int u)
{
if(l==r)
{
tr[u].mn=(ui)p[l].v;
return ;
}
int mid = (l+r)>>;
build(l,mid,u<<);
build(mid+,r,u<<|);
update(u);
}
segtree query(int l,int r,int u,int ql,int qr)
{
if(l==ql&&r==qr)return tr[u];
int mid = (l+r)>>;
if(ql>mid)return query(mid+,r,u<<|,ql,qr);
else if(qr<=mid) return query(l,mid,u<<,ql,qr);
else
{
segtree s0=query(l,mid,u<<,ql,mid);
segtree s1=query(mid+,r,u<<|,mid+,qr);
segtree ret = s0 * s1;
return ret;
}
}
ui jc[];
int mi[];
int findl(int d)
{
int a = n;
for(int i=;i>=;i--)
{
if(a-mi[i]<=)continue;
if(p[a-mi[i]].d>=d)a-=mi[i];
}
return a;
}
int findr(int d)
{
int a = ;
for(int i=;i>=;i--)
{
if(a+mi[i]>n)continue;
if(p[a+mi[i]].d<=d)a+=mi[i];
}
return a;
}
int main()
{
// freopen("c.in","r",stdin);
// freopen("c.out","w",stdout);
scanf("%d%d",&n,&Q);
jc[]=,jc[]=,jc[]=,jc[]=,jc[]=,jc[]=;
mi[]=;
for(int i=;i<=;i++)mi[i]=mi[i-]<<;
for(int i=;i<=n;i++)scanf("%d",&p[i].d);
for(int i=;i<=n;i++)scanf("%d",&p[i].v);
sort(p+,p++n,cmp);
build(,n,);
for(int ll,rr,l,r,k,i=;i<=Q;i++)
{
scanf("%d%d%d",&ll,&rr,&k);
l = findl(ll);
r = findr(rr);
if(l>r)
{
printf("0\n");
continue;
}
segtree ans;
ans = query(,n,,l,r);
printf("%u\n",ans.v[k]*jc[k]);
}
fclose(stdin);
fclose(stdout);
return ;
}
Melancholy(磨懒虫主义)的更多相关文章
- HIFI播放器--磨机吐槽篇
最近看到淘宝店提供各种随身播放器磨机服务,说的是天花乱坠,给你更换零件, 甚至更改电路,搭载上去,是如何如何的好,整个播放器就上升了几个等次,收费还 不低,至少是好几百,我实在是忍不住吐槽了,你们这些 ...
- 高龄“潮男”优衣库老板柳井正_榜样_奢华主义_YOKA时尚网
高龄"潮男"优衣库老板柳井正_榜样_奢华主义_YOKA时尚网 高龄"潮男"优衣库老板柳井正
- python中multiprocessing.pool函数介绍_正在拉磨_新浪博客
python中multiprocessing.pool函数介绍_正在拉磨_新浪博客 python中multiprocessing.pool函数介绍 (2010-06-10 03:46:5 ...
- 作为一个懒虫,如何优雅的使用windows
懒虫windows系列(一) 首先是快捷键,因为自己太懒了,觉得用鼠标很麻烦,下面总结一下自己最常用的快捷键(windows10 ) Ctrl+Shift+N:新建文件夹 F2:重命名 Ctrl + ...
- 磨人的Fragment的转换
磨人的Fragment的转换 本次任务是 程序运行之后将第一个Fragment加载出来 然后点击"SHOW NEXT PAGE"切换到第二个Fragment 当再次点击按钮时下方出 ...
- 如何用ABP框架快速完成项目(9) - 用ABP一个人快速完成项目(5) - 不要执着于设计模式和DDD理论,避免原教旨主义
为什么要写这节文章呢? 首先主动看我这系列文章和参加活动课程的同学, 肯定是积极好学的. 所以很大概率是学过设计模式和DDD理论的. 很大概率不是走一点都不懂设计模式和DDD理论这个极端, 而是走 ...
- .NET开源项目 QuarkDoc 一款自带极简主义属性的文档管理系统
有些话说在前头 因为公司产品业务重构且功能拆分组件化,往后会有很多的接口文档需要留存,所以急需一款文档管理系统.当时选型要求3点: 1.不能是云平台上的Saas服务,整个系统都要在自己公司部署维护(数 ...
- Vim 利剑常磨,见血封喉
年底了,故事总是会有很多. 刚了一波通宵加班,趁着有时间,过了一遍Vim教程,顺便汇总下常用命令. 对于以 OSX / Linux为开发环境的伙伴们,应该并不陌生.因其轻便,扩展性,可定制化,一直很受 ...
- JavaScript学习总结(十三)——极简主义法编写JavaScript类
前两天在网上无意中发现了一篇使用极简主义法定义JavaScript类的文章,原文链接,这个所谓的"极简主义法"我还是第一次听说,是荷兰程序员Gabor de Mooij提出来的,这 ...
随机推荐
- bzoj 1060: [ZJOI2007]时态同步【树形dp】
可能算不上dp,大概是个树形模拟 先一遍dfs算出f[u]为每个点最深的叶子到u的距离,然后再dfs一下,ans加上f[u]-f[e[i].to]-e[i].va,f[u]-f[e[i].to]是这条 ...
- IDEA2018.3.5Tomcat output 中文乱码 修改配置文件生效的解决办法
首先,我也是尝试别人介绍的方法: IDEA Windows 环境 console 乱码问题 - intellij idea 15 控制台输出中文乱码问题解决办法 - liuhai的博客 - CSDN博 ...
- chrome调试中resource改到application中了
如题,看视频的时候发现在resource下面查看cookie,但是自己试的时候发现没有了这个工具, google之后发现原来该位置了
- 树状数组 POJ 2481 Cows
题目传送门 #include <cstdio> #include <cstring> #include <algorithm> using namespace st ...
- Backbone学习记录(7)
事件委托 <form> <input type="text" class="txt"> <input type="but ...
- Backbone学习记录(1)
去年买的<基于MVC的javascript Web富应用开发>,拖到现在还没看完,作者介绍了三个MVC框架,Spine ,backbone和javascriptMVC.1和2在国内的流行度 ...
- android开发学习 ------- Error:Failed to open zip file.
我们用Android Studio Sync Project项目的时候,会出现如下的错误: 解决方案: Project视图下, 这块 https 改为 http 就可以了.
- jsonp对付同源策略
当 协议不同或者域名/ip不同或者端口号不同 , 都不算是同源 这时候 源生的ajax 就不能进行数据请求了 JSONP json with padding 在平时的开发中也发现了 ,当我们请求 ...
- Android iconfont字体图标的使用
1.首先,进入阿里的矢量图标库,在这个图标库里面可以找到很多图片资源,当然了需要登录才能下载或者使用,用GitHub账号或者新浪微博账号登录都可以 2.登录以后,可以搜索自己需要的资源,然后直接下载使 ...
- IDEA下MyBatis错误总结
1. Pom.xml配置 语法顺序 <properties resource="config.properties"> </properties> < ...