考虑某两行a和b的dis

如果相同:$|a-b|$

如果不同:$n-|a-b|$

然后考虑三行的dis,不妨设a>=b>=c

那么有4种情况:

1.a,b,c 0/1的种类相同:$|a-b|+|a-c|+|b-c|=2a-2c$

2.a和b相同:$2n+2c-2b$

3.a和c相同:$2n$

4.b和c相同:$2n+2b-2a$

所以我们排序后枚举这个b,预处理出前缀和后缀的是0/1的最大值个数、最小值个数以及总共的个数,加一加乘一乘统计答案即可

注意如果记权值的时候用int,那要先减再加,防爆

 #include<bits/stdc++.h>
#define CLR(a,x) memset(a,x,sizeof(a))
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pa;
const int maxn=1e5+,inf=1e9+; inline ll rd(){
ll x=;char c=getchar();int neg=;
while(c<''||c>''){if(c=='-') neg=-;c=getchar();}
while(c>=''&&c<='') x=x*+c-'',c=getchar();
return x*neg;
} struct Node{
int v;ll n;
Node(int a=,ll b=){v=a,n=b;}
}f[][maxn][],g[][maxn][],ans;
int N,M;
pa a[maxn]; inline void update(int v1,ll n1){
// printf("~%d %d\n",v1,n1);
if(!n1) return;
if(v1>ans.v) ans=Node(v1,n1);
else if(v1==ans.v) ans=Node(v1,n1+ans.n);
} int main(){
//freopen("","r",stdin);
int i,j,k;
N=rd(),M=rd();
for(i=;i<=M;i++){
a[i].second=rd(),a[i].first=rd();
}sort(a+,a+M+);
f[][][].v=f[][][].v=g[][M+][].v=g[][M+][].v=inf;
for(i=;i<=M;i++){
int tp=a[i].second,x=a[i].first;
memcpy(f[!tp][i],f[!tp][i-],sizeof(f[][]));
if(x>f[tp][i-][].v) f[tp][i][]=Node(x,);
else if(x==f[tp][i-][].v) f[tp][i][]=Node(x,f[tp][i-][].n+);
else f[tp][i][]=f[tp][i-][]; if(x<f[tp][i-][].v) f[tp][i][]=Node(x,);
else if(x==f[tp][i-][].v) f[tp][i][]=Node(x,f[tp][i-][].n+);
else f[tp][i][]=f[tp][i-][]; f[tp][i][].n=f[tp][i-][].n+;
}
for(i=M;i;i--){
int tp=a[i].second,x=a[i].first;
memcpy(g[!tp][i],g[!tp][i+],sizeof(g[][]));
if(x>g[tp][i+][].v) g[tp][i][]=Node(x,);
else if(x==g[tp][i+][].v) g[tp][i][]=Node(x,g[tp][i+][].n+);
else g[tp][i][]=g[tp][i+][]; if(x<g[tp][i+][].v) g[tp][i][]=Node(x,);
else if(x==g[tp][i+][].v) g[tp][i][]=Node(x,g[tp][i+][].n+);
else g[tp][i][]=g[tp][i+][]; g[tp][i][].n=g[tp][i+][].n+;
} for(i=;i<=M-;i++){
int tp=a[i].second,x=a[i].first;
int v1=*g[tp][i+][].v-*f[tp][i-][].v;ll n1=g[tp][i+][].n*f[tp][i-][].n;
update(v1,n1); v1=*N-*x+*f[!tp][i-][].v,n1=f[!tp][i-][].n*g[tp][i+][].n;
update(v1,n1); v1=*N,n1=f[!tp][i-][].n*g[!tp][i+][].n;
update(v1,n1); v1=*N-*g[!tp][i+][].v+*x,n1=f[tp][i-][].n*g[!tp][i+][].n;
update(v1,n1);
}
printf("%I64d\n",ans.n);
return ;
}

cf406E Hamming Triples (推公式)的更多相关文章

  1. HDU 4873 ZCC Loves Intersection(JAVA、大数、推公式)

    在一个D维空间,只有整点,点的每个维度的值是0~n-1 .现每秒生成D条线段,第i条线段与第i维度的轴平行.问D条线段的相交期望. 生成线段[a1,a2]的方法(假设该线段为第i条,即与第i维度的轴平 ...

  2. HDU 4870 Rating(概率、期望、推公式) && ZOJ 3415 Zhou Yu

    其实zoj 3415不是应该叫Yu Zhou吗...碰到ZOJ 3415之后用了第二个参考网址的方法去求通项,然后这次碰到4870不会搞.参考了chanme的,然后重新把周瑜跟排名都反复推导(不是推倒 ...

  3. HDU 5047 推公式+别样输出

    题意:给n个‘M'形,问最多能把平面分成多少区域 解法:推公式 : f(n) = 4n(4n+1)/2 - 9n + 1 = (8n+1)(n-1)+2 前面部分有可能超long long,所以要转化 ...

  4. CCF 201312-4 有趣的数 (数位DP, 状压DP, 组合数学+暴力枚举, 推公式, 矩阵快速幂)

    问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...

  5. bjfu1211 推公式,筛素数

    题目是求fun(n)的值 fun(n)= Gcd(3)+Gcd(4)+…+Gcd(i)+…+Gcd(n).Gcd(n)=gcd(C[n][1],C[n][2],……,C[n][n-1])C[n][k] ...

  6. sgu495:概率dp / 推公式

    概率题..可以dp也可以推公式 抽象出来的题目大意: 有 n个小球,有放回的取m次  问 被取出来过的小球的个数的期望 dp维护两个状态 第 i 次取出的是 没有被取出来过的小球的 概率dp[i] 和 ...

  7. ASC(22)H(大数+推公式)

    High Speed Trains Time Limit: 4000/2000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) Su ...

  8. hdu_5810_Balls and Boxes(打表推公式)

    题目链接:hdu_5810_Balls and Boxes 题意: 如题,让你求那个公式的期望 题解: 打表找规律,然后推公式.这项技能必须得学会 #include<cstdio> #in ...

  9. hdu4507 数位dp+推公式

    推公式的能力需要锻炼.. /* dp的时候要存结构体 里面三个元素: cnt,就是满足条件的个数 sum1,就是满足条件的数字和 sum2,满足条件的数字平方和 推导过程:还是用记忆化搜索模板 dp[ ...

随机推荐

  1. Git Gerrit Code Review

    Gerrit Code Review | Gerrit Code Reviewhttps://www.gerritcodereview.com/

  2. windows 内建环境变量

    PS C:\Windows> ls env: Name Value ---- ----- _NT_SYMBOL_PATH srv*C:\Users\vv\Documents\symbols AL ...

  3. CentOS7安装k8s

    借鉴博客:https://www.cnblogs.com/xkops/p/6169034.html 此博客里面有每个k8s配置文件的注释:https://blog.csdn.net/qq_359048 ...

  4. csrf补充

    问csrftoken在Django里面是基于什么实现的?------>中间件. 如果是Django表示每次发请求过来的时候,要检验有没有带随机字符串.当在执行视图函数之前,前面还有一道屏障,这个 ...

  5. python爬虫之Splash使用初体验

    Splash是什么: Splash是一个Javascript渲染服务.它是一个实现了HTTP API的轻量级浏览器,Splash是用Python实现的,同时使用Twisted和QT.Twisted(Q ...

  6. windows10企业版2016长期服务版激活

    win10 2016 长期服务版的ISO文件中本身就带有KMS激活KEY,不用输入任何KEY,连接网络进入CMD,只要输入:slmgr /skms kms.digiboy.irslmgr /ato这两 ...

  7. Golang的md5 hash计算

    Golang计算md5值的方法都是接收byte型slice([]byte).而且使用习惯上也觉得略奇怪. 看了好几个例子才看懂. 感觉Golang标准库在设计这些模块的时候,都会考虑使用带New关键字 ...

  8. 将WCF寄宿在托管的Windows服务中

    在我之前的一篇博客中我介绍了如何发布WCF服务并将该服务寄宿于IIS上,今天我再来介绍一种方式,就是将WCF服务寄宿在Windows服务中,这样做有什么好处呢?当然可以省去部署IIS等一系列的问题,能 ...

  9. Java 基础类型 默认值

    (1)数据库里的列,如果有默认值,不能赋值有业务含义的值. (2)int 默认值 java会分配默认值的额.

  10. 三、kubernetes环境搭建(实践)

    一.目前近况 docker 版本 K8S支持 18.06的 二.安装docker #1.配置仓库 sudo yum install -y yum-utils device-mapper-persist ...