【NOIP2015模拟11.5】JZOJ8月5日提高组T2 Lucas的数列

题目





PS:\(n*n*T*T<=10^{18}\)而不是\(10^1*8\)

题解

题意:

给出\(n\)个元素的复杂度和位置

然后每次询问一个区间

每次询问给出\(x,y,z\)

求\(x\)到\(y\)中复杂度小于等于\(z\)的元素的位置按照一定计算过程后的答案(具体见题面)

分析:

看到题目给出的式子十分的繁琐

我们来化简一下

\[K=(\sum_{i=1}^m(x_i-p)^2)*m=(\sum_{i=1}^m((x_i)^2-2x_ip+p^2))*m=(\sum_{i=1}^m(x_i)^2-\sum_{i=1}^m2x_ip+\sum_{i=1}^mp^2)*m
\]
\[=(\sum_{i=1}^m(x_i)^2-\sum_{i=1}^m2x_i\dfrac{\sum_{i=1}^mx_i}{m}+m(\dfrac{\sum_{i=1}^mx_i}{m})^2)*m=m\sum_{i=1}^m(x_i)^2-2({\sum_{i=1}^mx_i})^2+({\sum_{i=1}^mx_i})^2=m\sum_{i=1}^m(x_i)^2-({\sum_{i=1}^mx_i})^2
\]

所以说,\(K\)其实一直都是个整数:\(m\sum_{i=1}^m(x_i)^2-({\sum_{i=1}^mx_i})^2\)

再看,这题并不要求在线

所以可以离线

按照\(w\)和\(z\)为第一关键字排序

然后维护一个\(j\)使得\(1\)~\(j\)内的\(w\)都小于当前的\(z\)

由于\(z\)是单调递增的,所以\(j\)不用清零

然后构造一棵线段树(树状数组)就可以了

Code

#include<cstdio>
#include<algorithm>
using namespace std;
struct node1
{
long long p,w,id;
}a[400005];
struct node2
{
long long x,y,z,lixian;
}c[400005];
struct node3
{
long long sum1,sum2,num;
}tree[1600005];
bool cmp1(node1 x,node1 y)
{
return x.w<y.w;
}
bool cmp2(node2 x,node2 y)
{
return x.z<y.z;
}
long long n,m,i,j;
long long s1,s2,s3,ans[400005];
void build(long long now,long long l,long long r,long long pos,long long val)
{
if (l==r)
{
if (l==pos)
{
tree[now].num=1;
tree[now].sum1=val*val;
tree[now].sum2=val;
}
return;
}
if (l>pos||r<pos) return;
long long mid=(l+r)>>1;
build(now<<1,l,mid,pos,val);
build(now<<1|1,mid+1,r,pos,val);
tree[now].num=tree[now<<1].num+tree[now<<1|1].num;
tree[now].sum1=tree[now<<1].sum1+tree[now<<1|1].sum1;
tree[now].sum2=tree[now<<1].sum2+tree[now<<1|1].sum2;
}
void query(long long now,long long l,long long r,long long p,long long q)
{
if (tree[now].num==0) return;
if (l>q||r<p) return;
if (l>=p&&r<=q)
{
s1+=tree[now].num;
s2+=tree[now].sum1;
s3+=tree[now].sum2;
return;
}
long long mid=(l+r)>>1;
query(now<<1,l,mid,p,q);
query(now<<1|1,mid+1,r,p,q);
}
int main()
{
freopen("sequence.in","r",stdin);
freopen("sequence.out","w",stdout);
scanf("%lld%lld",&n,&m);
for (i=1;i<=n;i++)
{
scanf("%lld%lld",&a[i].w,&a[i].p);
a[i].id=i;
}
for (i=1;i<=m;i++)
{
scanf("%lld%lld%lld",&c[i].x,&c[i].y,&c[i].z);
c[i].lixian=i;
}
sort(a+1,a+n+1,cmp1);
sort(c+1,c+m+1,cmp2);
j=1;
for (i=1;i<=m;i++)
{
while (a[j].w<=c[i].z&&j<=n)
{
build(1,1,n,a[j].id,a[j].p);
j++;
}
s1=s2=s3=0;
query(1,1,n,c[i].x,c[i].y);
if (s1==0) ans[c[i].lixian]=-1;
else ans[c[i].lixian]=s1*s2-s3*s3;
}
for (i=1;i<=m;i++)
{
if (ans[i]==-1) printf("empty\n");
else printf("%lld\n",ans[i]);
}
fclose(stdin);
fclose(stdout);
return 0;
}

【NOIP2015模拟11.5】JZOJ8月5日提高组T2 Lucas的数列的更多相关文章

  1. 【NOIP2015模拟11.2晚】JZOJ8月4日提高组T2 我的天

    [NOIP2015模拟11.2晚]JZOJ8月4日提高组T2 我的天 题目 很久很以前,有一个古老的村庄--xiba村,村子里生活着n+1个村民,但由于历届村长恐怖而且黑暗的魔法统治下,村民们各自过着 ...

  2. JZOJ8月10日提高组T2 Fix

    JZOJ8月10日提高组T2 Fix 题目 Description There are a few points on a plane, and some are fixed on the plane ...

  3. 【NOIP2015模拟11.5】JZOJ8月5日提高组T1 俄罗斯套娃

    [NOIP2015模拟11.5]JZOJ8月5日提高组T1 俄罗斯套娃 题目 题解 题意就是说 将1~\(n\)排列,问有多少种方案使得序列的逆序对个数小于\(k\) 很容易想到DP 设\(f[i][ ...

  4. 【NOIP2015模拟11.4】JZOJ8月6日提高组T1 刷题计划

    [NOIP2015模拟11.4]JZOJ8月6日提高组T1 刷题计划 题目 题解 题意 有\(n\)道题,编号为1~\(n\) 给出\(m\)次操作 每次操作有3种类型 1 \(x\) 表示交了\(A ...

  5. 【NOIP2015模拟11.5】JZOJ8月5日提高组T3 旅行

    [NOIP2015模拟11.5]JZOJ8月5日提高组T3 旅行 题目 若不存在第\(k\)短路径时,输出"Stupid Mike" 题解 题意 给出一个有\(n\)个点的树 问这 ...

  6. 【NOIP2015模拟11.4】JZOJ2020年8月6日提高组T2 最优交换

    [NOIP2015模拟11.4]JZOJ2020年8月6日提高组T2 最优交换 题目 题解 题意 有一个长度为\(n\)的正整数 最多可以进行\(k\)次操作 每次操作交换相邻两个位置上的数 问可以得 ...

  7. JZOJ8月4日提高组反思

    JZOJ8月4日提高组反思 被一堆2018&2019&2020的巨佬暴打 又是愉快的爆0的一天呢 T1 看了看题 没想法 暴力走起 求个质因数呀,二分呀-- 然后就炸了 正解预处理加二 ...

  8. JZOJ8月10日提高组反思

    JZOJ8月10日提高组反思 T1 没想到怎么打 就去打暴力了 本来想拿个30不错了 结果\(AC\)了 话说回来,数据也挺小的 T2 不AC便爆0 就一个数据点 给不给打暴力的人活了 正解是状压DP ...

  9. JZOJ8月15日提高组反思——2020年暑假终结篇

    JZOJ8月15日提高组反思--2020年暑假终结篇 T1 仙人掌最短路 抱歉我只会最短路 仙人掌是啥? 听说是缩点+\(LCA\) 最短路30 T2 直接暴力计算 正解\(DP\) \(amazin ...

随机推荐

  1. (二)http请求方法和状态码

    1.HTTP请求方法 根据 HTTP 标准,HTTP 请求可以使用多种请求方法. HTTP1.0 定义了三种请求方法: GET.POST 和 HEAD方法. HTTP1.1 新增了六种请求方法:OPT ...

  2. leetcode72:combinations

    题目描述 给出两个整数n和k,返回从1到n中取k个数字的所有可能的组合 例如: 如果n=4,k=2,结果为 [↵ [2,4],↵ [3,4],↵ [2,3],↵ [1,2],↵ [1,3],↵ [1, ...

  3. dict和list

    一.字典(Dictionary) 1.什么是 dict(字典) 上一章节,我们学习了列表(List) 和 元组(tuple) 来表示有序集合. 而我们在讲列表(list)的时候,我们用了列表(list ...

  4. 对Spark硬件配置的建议

    对于Spark开发人员来说,一个比较普遍的问题就是如何合理的配置Spark的硬件?当然如何合理的对Spark集群进行硬件配置要视情况而定,在这里给出以下建议: 存储系统 在大数据领域,有一句" ...

  5. webpack配置babel篇

    babel-polyfill & babel-runtime & babel-preset-env babel-core babel-core 的作用是把 js 代码分析成 ast , ...

  6. vue实现带logo的二维码/商品条形码/打印商品吊牌

    一.带logo的二维码 1.安装 npm install vue-qr --save 2.在页面或组件中使用 <template> <div id="qrcode" ...

  7. GSO和TSO

    http://www.cnhalo.net/2016/09/13/linux-tcp-gso-tso/ TSO(TCP Segmentation Offload): 是一种利用网卡来对大数据包进行自动 ...

  8. 幻读在 InnoDB 中是被如何解决的?(转)

    在MySQL事务初识中,我们了解到不同的事务隔离级别会引发不同的问题,如在 RR 级别下会出现幻读.但如果将存储引擎选为 InnoDB ,在 RR 级别下,幻读的问题就会被解决.在这篇文章中,会先介绍 ...

  9. Java的注释-标识符和关键字

    1.Java注释 单行注释 多行注释 文档注释 代码示例 public class Hello{    public static void main(String[] args) {         ...

  10. Cassandra存储附带索引(SAI)全新上线

    新一代Apache Cassandra索引现已在Astra和DataStax Enterprise 6.8.3中正式开放使用 (general availability or GA),很快您也将在开源 ...