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[ ...
随机推荐
- selenium处理alert弹出框
import time from selenium import webdriver driver =webdriver.Chrome(r"D:\工具包\chromedriver.exe&q ...
- 开发神器之phpstorm破解与日常使用
PhpStorm 是 JetBrains 公司开发的一款商业的 PHP 集成开发工具,旨在提高用户效率,可深刻理解用户的编码,提供智能代码补全,快速导航以及即时错误检查. PhpStorm可随时帮助用 ...
- Spring boot 将配置文件属性注入到一个bean中
现在要做的就是将如下配置文件中的内容注入到一个bean 名为Properties中. Redis.properties配置文件中的内容如下: Properties java bean中代码如下,注意注 ...
- 小程序和H5互调
小程序跳H5页面 https://blog.csdn.net/mytljp/article/details/81030687(copy) H5页面跳小程序 https://blog.csdn.net/ ...
- vue 动态插入组件
HTML代码: <div id="app"> <p>{{ message }}</p> <button @click="add( ...
- java 从键盘录入的三种方法
详细内容连接 https://blog.csdn.net/StriverLi/article/details/52984066
- socket基础编程-1
server端和client端 1.server端: import socket server=socket.socket() server.bind(('localhost',8080)) serv ...
- JQ 动态修改/替换某个节点的内容
<div class="box">我们定位于中国心理行业第一<div> $(".box").html($(".box&quo ...
- linux通过命令行查看MySQL编码并修改-简洁版方法
云服务器环境:CentOS 7.4 因为服务器配置较低,故使用MySQL5.5 未进行设置前 1.查看字符编码: mysql> show variables like '%character%' ...
- Lodop打印较大的超出纸张的图片
ADD_PRINT_IMAGE打印图片时,如果一个图片过大,超出纸张,默认超出部分是不显示的,也不会分页.最近遇到有人利用ADD_PRINT_URL打印图片,说图片自动分了多页,因为这个方法一般是用来 ...