题目大意:给出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(磨懒虫主义)的更多相关文章

  1. HIFI播放器--磨机吐槽篇

    最近看到淘宝店提供各种随身播放器磨机服务,说的是天花乱坠,给你更换零件, 甚至更改电路,搭载上去,是如何如何的好,整个播放器就上升了几个等次,收费还 不低,至少是好几百,我实在是忍不住吐槽了,你们这些 ...

  2. 高龄“潮男”优衣库老板柳井正_榜样_奢华主义_YOKA时尚网

    高龄"潮男"优衣库老板柳井正_榜样_奢华主义_YOKA时尚网 高龄"潮男"优衣库老板柳井正

  3. python中multiprocessing.pool函数介绍_正在拉磨_新浪博客

    python中multiprocessing.pool函数介绍_正在拉磨_新浪博客     python中multiprocessing.pool函数介绍    (2010-06-10 03:46:5 ...

  4. 作为一个懒虫,如何优雅的使用windows

    懒虫windows系列(一) 首先是快捷键,因为自己太懒了,觉得用鼠标很麻烦,下面总结一下自己最常用的快捷键(windows10 ) Ctrl+Shift+N:新建文件夹 F2:重命名 Ctrl + ...

  5. 磨人的Fragment的转换

    磨人的Fragment的转换 本次任务是 程序运行之后将第一个Fragment加载出来 然后点击"SHOW NEXT PAGE"切换到第二个Fragment 当再次点击按钮时下方出 ...

  6. 如何用ABP框架快速完成项目(9) - 用ABP一个人快速完成项目(5) - 不要执着于设计模式和DDD理论,避免原教旨主义

    为什么要写这节文章呢?   首先主动看我这系列文章和参加活动课程的同学, 肯定是积极好学的. 所以很大概率是学过设计模式和DDD理论的. 很大概率不是走一点都不懂设计模式和DDD理论这个极端, 而是走 ...

  7. .NET开源项目 QuarkDoc 一款自带极简主义属性的文档管理系统

    有些话说在前头 因为公司产品业务重构且功能拆分组件化,往后会有很多的接口文档需要留存,所以急需一款文档管理系统.当时选型要求3点: 1.不能是云平台上的Saas服务,整个系统都要在自己公司部署维护(数 ...

  8. Vim 利剑常磨,见血封喉

    年底了,故事总是会有很多. 刚了一波通宵加班,趁着有时间,过了一遍Vim教程,顺便汇总下常用命令. 对于以 OSX / Linux为开发环境的伙伴们,应该并不陌生.因其轻便,扩展性,可定制化,一直很受 ...

  9. JavaScript学习总结(十三)——极简主义法编写JavaScript类

    前两天在网上无意中发现了一篇使用极简主义法定义JavaScript类的文章,原文链接,这个所谓的"极简主义法"我还是第一次听说,是荷兰程序员Gabor de Mooij提出来的,这 ...

随机推荐

  1. MAC下如何配置Android手机调试(将测试手机加入到Mac系统的调试列表中)

    第一步: 查看usb设备信息 在 终端输入:system_profiler SPUSBDataType     可以查看连接的usb设备的信息 比如我的usb信息如下(部分内容): 查看到我的Andr ...

  2. java笔记1:准备工作:java历史、Java环境、java编辑器、cmd常用命令

    java的历史 Java是由Sun Microsystems公司于1995年5月推出的Java面向对象程序设计语言和Java平台的总称. 由James Gosling和同事们共同研发,并在1995年正 ...

  3. Codeforces 1107G(dp)

    1.答案要取连续的区间疯狂暗示线段树. 2.外层枚举r,内层枚举l显然过于暴力. 3.考虑内层的优化.dp[i]:以第i位为结尾的答案(长度大于1的).dp[i] = max(第一种情况,第二种情况) ...

  4. Building Forest CodeForces - 195E

    Building Forest CodeForces - 195E 这题意真是难懂啊...话说"An oriented weighted forest is an acyclic weigh ...

  5. Lucas+中国剩余定理 HDOJ 5446 Unknown Treasure

    题目传送门 题意:很裸,就是求C (n, m) % (p1 * p2 * p3 * .... * pk) 分析:首先n,m<= 1e18, 要用到Lucas定理求大组合数取模,当然p[]的乘积& ...

  6. Eclipse安装svn插件的几种方式 -- 转

    1.在线安装: (1).点击 Help --> Install New Software... (2).在弹出的窗口中点击add按钮,输入Name(任意)和Location(插件的URL),点击 ...

  7. 01.第一章_C++ Primer学习笔记_开始

    1.2 初始输入输出 iostream库里面包含两个基础类型istream和ostream,分别表示输入流和输出流,一个流就是一个字符序列,从IO设备读出或者写入IO设备. 标准的输入输出对象 标准库 ...

  8. 在colab上运行style-transfer

    1,  打开chrome浏览器,输入以下网址,打开风格转换主文件 https://colab.research.google.com/github/Hvass-Labs/TensorFlow-Tuto ...

  9. python+selenium(环境的安装)

    前言:网上的资料层次不齐,且资料也不全,容易误导新手,所以笔者愿意把你的知识免费分享给大家,笔者用的版本为:python3 此时可能新手就会问了,为什么不用python2呢,因为道理很简单,人要往前走 ...

  10. iptables规则的关系

    iptables规则的关系,是自上而下进行过虑的.所以添加规则时,要通过文件进行添加,这样的话,可以控制其顺序. A机器: [root@www ~]# netstat -an | grep 6100 ...