【NOIP2015模拟11.5】JZOJ8月5日提高组T2 Lucas的数列
【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\)其实一直都是个整数:\(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的数列的更多相关文章
- 【NOIP2015模拟11.2晚】JZOJ8月4日提高组T2 我的天
[NOIP2015模拟11.2晚]JZOJ8月4日提高组T2 我的天 题目 很久很以前,有一个古老的村庄--xiba村,村子里生活着n+1个村民,但由于历届村长恐怖而且黑暗的魔法统治下,村民们各自过着 ...
- JZOJ8月10日提高组T2 Fix
JZOJ8月10日提高组T2 Fix 题目 Description There are a few points on a plane, and some are fixed on the plane ...
- 【NOIP2015模拟11.5】JZOJ8月5日提高组T1 俄罗斯套娃
[NOIP2015模拟11.5]JZOJ8月5日提高组T1 俄罗斯套娃 题目 题解 题意就是说 将1~\(n\)排列,问有多少种方案使得序列的逆序对个数小于\(k\) 很容易想到DP 设\(f[i][ ...
- 【NOIP2015模拟11.4】JZOJ8月6日提高组T1 刷题计划
[NOIP2015模拟11.4]JZOJ8月6日提高组T1 刷题计划 题目 题解 题意 有\(n\)道题,编号为1~\(n\) 给出\(m\)次操作 每次操作有3种类型 1 \(x\) 表示交了\(A ...
- 【NOIP2015模拟11.5】JZOJ8月5日提高组T3 旅行
[NOIP2015模拟11.5]JZOJ8月5日提高组T3 旅行 题目 若不存在第\(k\)短路径时,输出"Stupid Mike" 题解 题意 给出一个有\(n\)个点的树 问这 ...
- 【NOIP2015模拟11.4】JZOJ2020年8月6日提高组T2 最优交换
[NOIP2015模拟11.4]JZOJ2020年8月6日提高组T2 最优交换 题目 题解 题意 有一个长度为\(n\)的正整数 最多可以进行\(k\)次操作 每次操作交换相邻两个位置上的数 问可以得 ...
- JZOJ8月4日提高组反思
JZOJ8月4日提高组反思 被一堆2018&2019&2020的巨佬暴打 又是愉快的爆0的一天呢 T1 看了看题 没想法 暴力走起 求个质因数呀,二分呀-- 然后就炸了 正解预处理加二 ...
- JZOJ8月10日提高组反思
JZOJ8月10日提高组反思 T1 没想到怎么打 就去打暴力了 本来想拿个30不错了 结果\(AC\)了 话说回来,数据也挺小的 T2 不AC便爆0 就一个数据点 给不给打暴力的人活了 正解是状压DP ...
- JZOJ8月15日提高组反思——2020年暑假终结篇
JZOJ8月15日提高组反思--2020年暑假终结篇 T1 仙人掌最短路 抱歉我只会最短路 仙人掌是啥? 听说是缩点+\(LCA\) 最短路30 T2 直接暴力计算 正解\(DP\) \(amazin ...
随机推荐
- 释放至强平台 AI 加速潜能 汇医慧影打造全周期 AI 医学影像解决方案
基于英特尔架构实现软硬协同加速,显著提升新冠肺炎.乳腺癌等疾病的检测和筛查效率,并帮助医疗科研平台预防"维度灾难"问题 <PAGE 1 LEFT COLUMN: CUSTOM ...
- 小规模DES手写加解密
1.加密 2.解密
- 转载:Pycharm的常用快捷键
一直想着找一下pycharm的快捷键,但是每次都忘记找了,这次刚好碰到一个很全的,就直接借用别人的来当作自己的笔记ba 转载来源:https://www.cnblogs.com/liangmingsh ...
- C++ 基础 4:继承和派生
1 继承和派生 在 C++ 中 可重用性是通过继承这一机制实现的.继承允许我们依据另一个类来定义一个类,这使得创建和维护一个应用程序变得更容易.这样做,也达到了重用代码功能和提高执行效率的效果. 当创 ...
- 【python】将变量保存在本地及读取
在用jupyter notebook写python代码的过程中会产生很多变量,而关闭后或者restart jupyter kernel后所有变量均会消失,想要查看变量就必须将代码重新再运行一遍,而想在 ...
- Find Any File for Mac(文件搜索软件)v2.1.2b6
Find Any File for Mac是应用在Mac上的一款文件搜索工具,Find Any File Mac可以通过名称.创建或修改日期,大小或类型和创建者代码(而不是内容)在本地磁盘上搜索文件. ...
- httpserver ---tcp参数设置
1.SO_REUSEADDR选项: 在服务器程序中,SO_REUSEADDR socket选项通常在调用bind()之前被设置.SO_REUSEADDR可以用在以下四种情况下: (摘自<Unix ...
- prop()和attr()我该翻谁的牌子?
先上代码: // 全选 function CheckAll() { if ($("#th_checkbox").prop('checked')) $('input[name=&qu ...
- spring 2.5 基础知识和与其他框架的集成
spring环境搭建: 一:导入spring2.5所需的包,在classpath目录下建一个名为"beans.xml"模板文件: <?xml version="1. ...
- 使用create-react-app 搭建react + ts + antd框架
一.创建项目 使用npx create-react-app (项目名) --template typescript 创建项目 ①如果App.tsx文件有如下报错: (没有报错的请忽略) 需要将tsco ...