cf406E Hamming Triples (推公式)
考虑某两行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 (推公式)的更多相关文章
- HDU 4873 ZCC Loves Intersection(JAVA、大数、推公式)
在一个D维空间,只有整点,点的每个维度的值是0~n-1 .现每秒生成D条线段,第i条线段与第i维度的轴平行.问D条线段的相交期望. 生成线段[a1,a2]的方法(假设该线段为第i条,即与第i维度的轴平 ...
- HDU 4870 Rating(概率、期望、推公式) && ZOJ 3415 Zhou Yu
其实zoj 3415不是应该叫Yu Zhou吗...碰到ZOJ 3415之后用了第二个参考网址的方法去求通项,然后这次碰到4870不会搞.参考了chanme的,然后重新把周瑜跟排名都反复推导(不是推倒 ...
- HDU 5047 推公式+别样输出
题意:给n个‘M'形,问最多能把平面分成多少区域 解法:推公式 : f(n) = 4n(4n+1)/2 - 9n + 1 = (8n+1)(n-1)+2 前面部分有可能超long long,所以要转化 ...
- CCF 201312-4 有趣的数 (数位DP, 状压DP, 组合数学+暴力枚举, 推公式, 矩阵快速幂)
问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...
- 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] ...
- sgu495:概率dp / 推公式
概率题..可以dp也可以推公式 抽象出来的题目大意: 有 n个小球,有放回的取m次 问 被取出来过的小球的个数的期望 dp维护两个状态 第 i 次取出的是 没有被取出来过的小球的 概率dp[i] 和 ...
- ASC(22)H(大数+推公式)
High Speed Trains Time Limit: 4000/2000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) Su ...
- hdu_5810_Balls and Boxes(打表推公式)
题目链接:hdu_5810_Balls and Boxes 题意: 如题,让你求那个公式的期望 题解: 打表找规律,然后推公式.这项技能必须得学会 #include<cstdio> #in ...
- hdu4507 数位dp+推公式
推公式的能力需要锻炼.. /* dp的时候要存结构体 里面三个元素: cnt,就是满足条件的个数 sum1,就是满足条件的数字和 sum2,满足条件的数字平方和 推导过程:还是用记忆化搜索模板 dp[ ...
随机推荐
- mysql备份(导出)数据库,并恢复数据
导出某个数据库数据到文件中 假设要导出test这个数据库,那么可以在Linux命令行(不是在mysql中) [root@ubuntu /data]# mysqldump -uroot -p test ...
- 学习 yii2.0——视图之间相互包含
布局 首先创建一个布局文件simple.php,路径是在views/layout/目录下. <p>this is header</p> <?= $content ?> ...
- linux如何查看所有的用户(user)、用户组(group)、密码(password/passwd)
linux如何查看所有的用户和组信息_百度经验https://jingyan.baidu.com/article/a681b0de159b093b184346a7.html linux添加用户.用户组 ...
- C#设计模式之8:外观模式
外观模式 外观模式和适配器模式一样,都实现了接口改变,适配器模式是让一个接口转化成另外一个接口,而外观模式是让接口变得更简单. 先来看一下需求: 外观模式没有封装子系统的类,外观只是提供一个统一的接口 ...
- Linux(CentOS7)命令学习摘要
1. 修改机器名 hostnamectl set-hostname newname 2. hosts主机存放位置 /etc/hosts 3. 安装tigervncserver, 然后使用vncserv ...
- Oracle创建表空间、用户以及给用户赋权
--创建表空间 create tablespace waterboss datafile 'd:\waterboss.dbf' size 100m autoextend on next 10m --创 ...
- Laravel技巧:使用load、with预加载 区别
1.使用load $posts = Post::all(); $posts->load('user'); 2.使用with $posts = Post::with('user')->all ...
- spring 在容器中一个bean依赖另一个bean 需要通过ref方式注入进去 通过构造器 或property
spring 在容器中一个bean依赖另一个bean 需要通过ref方式注入进去 通过构造器 或property
- 使用js主函数的原因是等文档加载完了才给里面的元素添加东西 如果不使用主函数则文档加载时候无法找到元素则不能成功给元素添加事件
使用js主函数的原因是等文档加载完了才给里面的元素添加东西 如果不使用主函数则文档加载时候无法找到元素则不能成功给元素添加事件
- VS Code 编辑器
使用VS Code 编辑器有一段时间了,感觉非常好用,已经成为了我的第一选择了.现在需要学习了一下了. 1,更改编辑器的默认设置 文件 =>首选项 => 设置 或 ctrl + ,(逗号) ...