JZOJ 4018 Magic

Posted rrsb

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JZOJ 4018 Magic相关的知识,希望对你有一定的参考价值。

Description

圆上有 2 ∗ n 个点和连接这些点的 n 条弦,这些弦不会在圆上相交。这2 ∗ n 个点按照在圆上的位置顺序依次标号为 1,2,...,2 ∗ n。
请求出有多少个无序的三元组,使得对应的三条弦可以通过距离的缩放中心对称。

Input

第一行一个数 n (n ≤ 100000)。
接下来 n 行,每行两个数,表示该弦的端点。保证一个数不会出现两次。

Output

输出一个数,表示方案数。
 

Sol 

读不懂题系列,(⊙o⊙)…

原题cf 297E。

题目让我们找三条线段让两两端点距离相等。

技术分享图片

不知道为什么,我写了个莫队。

#pragma GCC optimize("-Ofast")
#include<bits/stdc++.h>
#define pii pair<int,int>
#define x first
#define N 2000007
#define y second
using namespace std;
#define sight(x) (‘0‘<=x&&x<=‘9‘)
inline void read(int &x){
    static char c;
    for (c=getchar();!sight(c);c=getchar());
    for (x=0;sight(c);c=getchar())x=x*10+c-48;
}
int n,l,r,B;
inline bool cmp(pii X,pii Y) {
    return (X.x/B==Y.x/B)?(X.y<Y.y):(X.x<Y.x);
}
int li,ri,zi,now[N],id[N],s,R[N],s2[N];pii p[N];
inline void add(int x){
    zi+=now[id[x]]?-1:1;
    now[id[x]]^=1;
}
signed main () {
    freopen("magic6.in","r",stdin);
    scanf("%d",&n);
    B=sqrt(7*n);
    for (int i=1;i<=n;i++) {
      read(p[i].x); read(p[i].y);
      if (p[i].x>p[i].y) swap(p[i].x,p[i].y);
      id[p[i].x]=i; id[p[i].y]=i;
    }
    sort(p+1,p+n+1,cmp);
    long long ans=1ll*n*(n-1)/2*(n-2)/3;
    l=1;
    for (int i=1;i<=n;i++) {
        while (r<p[i].y) add(++r);
        while (l>p[i].x) add(--l);
        while (r>p[i].y) add(r--);
        while (l<p[i].x) add(l++);
        li=p[i].y-1-p[i].x-zi>>1;
        ri=n-1-zi-li;
        ans-=1ll*li*ri;
        ans-=1ll*(n-1-zi)*zi/2;
    } 
    printf("%lld
",ans);
    return 0;
//    for (int i=1;i<=2*n;i++) {
//        
//    }
    return 0;
}

 

 

以上是关于JZOJ 4018 Magic的主要内容,如果未能解决你的问题,请参考以下文章

python jupyter magic命令片段

我的代码错误类型警告 1 警告 C4018 和更多错误

错误MSB4018 “ResolvePackageAssets”任务意外失败的解决方法

MSB4018 “ResolveComReference”任务意外失败

C4018:类内有符号、无符号不匹配

gcc 等效于 VC++ 警告 C4018: 有符号/无符号不匹配