「SNOI2017」一个简单的询问

简单的解法

显然可以差分一下。

\[get(l,r,x)\times get(l1,r1,x)=get(1,r,x) \times get(1,r1,x)-get(1,l-1,x) \times get(1,r1,x)-get(1,r,x) \times get(1,l1-1,x)+get(1,l-1,x) \times get(1,l1-1,x)
\]

因为都是1为起始,那么记两个cnt数组,表示前缀,然后可以分成四个区间,莫队。

#include <bits/stdc++.h>
#define rep(q, a, b) for (int q = a, q##_end_ = b; q <= q##_end_; ++q)
#define dep(q, a, b) for (int q = a, q##_end_ = b; q >= q##_end_; --q)
#define mem(a, b) memset(a, b, sizeof a)
#define debug(a) cerr << #a << ' ' << a << "___" << endl
using namespace std;
bool cur1;
char buf[10000000], *p1 = buf, *p2 = buf;
#define Getchar() p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 10000000, stdin), p1 == p2) ? EOF : *p1++
void in(int &r) {
static char c;
r = 0;
while (c = Getchar(), c < 48)
;
do
r = (r << 1) + (r << 3) + (c ^ 48);
while (c = Getchar(), c > 47);
}
const int mn = 50005;
int K, n, val[mn];
long long ans[mn];
struct node {
int l, r, id, ty;
bool operator<(const node &A) const {
return l / K == A.l / K ? (l / K & 1 ? r > A.r : r < A.r) : l / K < A.l / K;
}
} an[mn * 4];
int cnt[mn], cnt1[mn];
long long mid_ans;
bool cur2;
int main() {
// cerr<<(&cur2-&cur1)/1024.0/1024<<endl;
in(n);
K = sqrt(n) + 1;
rep(q, 1, n) in(val[q]);
int Q;
in(Q);
int l, r, l1, r1;
int ct = 0;
rep(q, 1, Q) {
in(l), in(r), in(l1), in(r1);
an[++ct] = { r, r1, q, 1 };
if (l > 1) {
an[++ct] = { l - 1, r1, q, -1 };
if (l1 > 1)
an[++ct] = { l1 - 1, l - 1, q, 1 };
}
if (l1 > 1)
an[++ct] = { l1 - 1, r, q, -1 };
}
sort(an + 1, an + ct + 1);
l = 0, r = 0;
rep(q, 1, ct) {
while (l > an[q].l) mid_ans -= cnt1[val[l]], --cnt[val[l--]];
while (r < an[q].r) mid_ans += cnt[val[++r]], ++cnt1[val[r]];
while (l < an[q].l) mid_ans += cnt1[val[++l]], ++cnt[val[l]];
while (r > an[q].r) mid_ans -= cnt[val[r]], --cnt1[val[r--]];
ans[an[q].id] += mid_ans * an[q].ty;
}
rep(q, 1, Q) printf("%lld\n", ans[q]);
return 0;
}

麻烦的解法

对于两个区间\([l,r],[l1,r1](l \leq l1)\),分三类容斥:

  1. 没有交
  2. \([l1,r1]\)被\([l,r]\)包含
  3. 两个区间相交且没有包含关系

对于1

\([l,r]\)值为K数有x,\([r+1,l1-1]\)值为K数有y,\([l1,r1]\)值为K数有z。

\[xz= {(x+y+z)^2-(x+y)^2-(y+z)^2+y^2\over 2}
\]

因此可以拆成4个区间计算。

对于2

\([l,l1-1]\)值为K数有x,\([l1,r1]\)值为K数有y,\([r1+1,r]\)值为K数有z。

\[y(x+y+z)={(x+y)^2+(y+z)^2-x^2-z^2 \over 2}
\]

因此可以拆成4个区间计算。

对于3

\([l,l1-1]\)值为K数有x,\([l1,r]\)值为K数有y,\([r+1,r1]\)值为K数有z。

\[(x+y)(y+z)= {(x+y+z)^2-x^2-z^2+y^2\over 2}
\]

因此可以拆成4个区间计算。

综上

一遍莫队即可,计算区间中相同数个数的平方的和。

#include<bits/stdc++.h>
#define rep(q,a,b) for(int q=a,q##_end_=b;q<=q##_end_;++q)
#define dep(q,a,b) for(int q=a,q##_end_=b;q>=q##_end_;--q)
#define mem(a,b) memset(a,b,sizeof a )
#define debug(a) cerr<<#a<<' '<<a<<"___"<<endl
using namespace std;
bool cur1;
char buf[10000000],*p1=buf,*p2=buf;
#define Getchar() p1==p2&&(p2=(p1=buf)+fread(buf,1,10000000,stdin),p1==p2)?EOF:*p1++
void in(int &r) {
static char c;
r=0;
while(c=Getchar(),c<48);
do r=(r<<1)+(r<<3)+(c^48);
while(c=Getchar(),c>47);
}
const int mn=50005;
int K,n,val[mn];
long long ans[mn];
struct node{
int l,r,id,ty;
bool operator <(const node &A)const{
return l/K==A.l/K?(l/K&1?r>A.r:r<A.r):l/K<A.l/K;
}
}an[mn*4];
int cnt[mn];
long long mid_ans;
bool cur2;
int main(){
// cerr<<(&cur2-&cur1)/1024.0/1024<<endl;
in(n);
K=sqrt(n)+1;
rep(q,1,n)in(val[q]);
int Q;
in(Q);
int l,r,l1,r1;
int ct=0;
rep(q,1,Q){
in(l),in(r),in(l1),in(r1);
if(l>l1)swap(l,l1),swap(r,r1);
if(r<l1){
an[++ct]={l,r1,q,1};
an[++ct]={l,l1-1,q,-1};
an[++ct]={r+1,r1,q,-1};
if(l1-1>=r+1)an[++ct]={r+1,l1-1,q,1};
}else if(r1<=r){
an[++ct]={l,r1,q,1};
an[++ct]={l1,r,q,1};
if(l<=l1-1)an[++ct]={l,l1-1,q,-1};
if(r1+1<=r)an[++ct]={r1+1,r,q,-1};
}else{
an[++ct]={l,r1,q,1};
an[++ct]={l1,r,q,1};
if(l<=l1-1)an[++ct]={l,l1-1,q,-1};
if(r+1<=r1)an[++ct]={r+1,r1,q,-1};
}
}
sort(an+1,an+ct+1);
mid_ans=1,cnt[val[1]]=1;
l=1,r=1;
rep(q,1,ct){
while(l>an[q].l)--l,mid_ans+=(cnt[val[l]]++)<<1|1;
while(r<an[q].r)++r,mid_ans+=(cnt[val[r]]++)<<1|1;
while(l<an[q].l)mid_ans-=(--cnt[val[l]])<<1|1,++l;
while(r>an[q].r)mid_ans-=(--cnt[val[r]])<<1|1,--r;
ans[an[q].id]+=mid_ans*an[q].ty;
}
rep(q,1,Q)printf("%lld\n",ans[q]>>1);
return 0;
}

「SNOI2017」一个简单的询问的更多相关文章

  1. loj #2254. 「SNOI2017」一个简单的询问

    #2254. 「SNOI2017」一个简单的询问 题目描述 给你一个长度为 NNN 的序列 aia_ia​i​​,1≤i≤N1\leq i\leq N1≤i≤N,和 qqq 组询问,每组询问读入 l1 ...

  2. loj2254 「SNOI2017」一个简单的询问

    ref #include <algorithm> #include <iostream> #include <cstdio> #include <cmath& ...

  3. [SNOI2017]一个简单的询问

    [SNOI2017]一个简单的询问 题目大意: 给定一个长度为\(n(n\le50000)\)的序列\(A(1\le A_i\le n)\),定义\(\operatorname{get}(l,r,x) ...

  4. 【BZOJ5016】[Snoi2017]一个简单的询问 莫队

    [BZOJ5016][Snoi2017]一个简单的询问 Description 给你一个长度为N的序列ai,1≤i≤N和q组询问,每组询问读入l1,r1,l2,r2,需输出 get(l,r,x)表示计 ...

  5. loj #2255. 「SNOI2017」炸弹

    #2255. 「SNOI2017」炸弹 题目描述 在一条直线上有 NNN 个炸弹,每个炸弹的坐标是 XiX_iX​i​​,爆炸半径是 RiR_iR​i​​,当一个炸弹爆炸时,如果另一个炸弹所在位置 X ...

  6. loj#2255. 「SNOI2017」炸弹 线段树优化建图,拓扑,缩点

    loj#2255. 「SNOI2017」炸弹 线段树优化建图,拓扑,缩点 链接 loj 思路 用交错关系建出图来,发现可以直接缩点,拓扑统计. 完了吗,不,瓶颈在于边数太多了,线段树优化建图. 细节 ...

  7. bzoj P5016[Snoi2017]一个简单的询问——solution

    Description 给你一个长度为N的序列ai,1≤i≤N和q组询问,每组询问读入l1,r1,l2,r2,需输出   get(l,r,x)表示计算区间[l,r]中,数字x出现了多少次. Input ...

  8. LOJ——#2256. 「SNOI2017」英雄联盟

    https://loj.ac/problem/2256 题目描述 正在上大学的小皮球热爱英雄联盟这款游戏,而且打的很菜,被网友们戏称为「小学生」.现在,小皮球终于受不了网友们的嘲讽,决定变强了,他变强 ...

  9. bzoj 5016: [Snoi2017]一个简单的询问

    Description 给你一个长度为N的序列ai,1≤i≤N和q组询问,每组询问读入l1,r1,l2,r2,需输出 get(l,r,x)表示计算区间[l,r]中,数字x出现了多少次. Input 第 ...

随机推荐

  1. Windows 11实现直播,VLC超简单实现捕获、串流、播放

    上一篇文章说了搭建Nginx的rtmp服务.实现直播功能 期间发现一个更便捷的工具 VLC media play,官方下载:https://www.videolan.org 1.傻瓜式安装,略过 2. ...

  2. 家用路由器也能充当Web服务器?路由器插件开发心得

    起因 最近刚刚结束考研,开始有时间写文章了.在复习的时候中,经常忍不住折腾各种东西,于是有一天看中了我手上的华为路由器.什么?华为路由器,你可能有这样的疑问,华为路由器不是自研的芯片吗,就像我手上这台 ...

  3. 关于 TCP/IP

    基于TCP/IP的参考模型将协议分成四个层次,它们分别是链路层.网络层.传输层和应用层. (1)应用层:这里面有http,ftp 等等我们熟悉的协议. (2)传输层:著名的TCP和UDP协议就在这个层 ...

  4. Java生成随机数的4种方式

    Random Random 类诞生于 JDK 1.0,它产生的随机数是伪随机数,也就是有规则的随机数.Random 使用的随机算法为 linear congruential pseudorandom ...

  5. 第十个知识点:RSA和强RSA问题有什么区别?

    第十个知识点:RSA和强RSA问题有什么区别 这个密码学52件事数学知识的第一篇,也是整个系列的第10篇.这篇介绍了RSA问题和Strong-RSA问题,指出了这两种问题的不同之处. 密码学严重依赖于 ...

  6. MA8601升级版 PL2586|USB HUB 工控级芯片方案PL2586|可直接替代FE1.1S芯片方案

    MA8601升级版 PL2586|USB HUB 工控级芯片方案PL2586|可直接替代FE1.1S芯片方案 旺玖在2022年新推出的一款USB HUB 芯片其性能和参数可以完全替代FE1.1S,是M ...

  7. 基于Spring MVC + Spring + MyBatis的【超市会员管理系统】

    资源下载: https://download.csdn.net/download/weixin_44893902/22035329 一. 语言和环境 实现语言:JAVA语言. 使用:MyEclipse ...

  8. LDAP服务端安装

    安装环境: 10.43.159.9 root/zdh1234 使用离线的yum源安装,如果机器重启过需要重新挂载镜像 mount /dev/cdrom /media/zidong/ 1.查看openl ...

  9. Ubuntu18.04升级内核后修改grub文件启动顺序

    采坑:之前线上的服务器内核是4.15.0,后面有的服务跑不起来,说是要升级内核,于是就升级了,然后改了/etc/default/grub的启动顺序,改错了就启动不起来了,哈哈.后面多次尝试还是改成功了 ...

  10. [ Flask ] myblog_flask问题集(RESTfull风格)

    VUE问题 前端VUE怎么捕获所有404NOT FOUND的路由呢? [ 解决方案 ] vue-router路由守卫,参考文档:动态路由匹配 对于路由.../edit/<id>,自己能编辑 ...