BSOJ6310题解
2024-10-20 12:14:49
互不相同,太困难啦!!!!!!
考虑可以相同的情况。可以容斥。
\[ans=(1+1+1+1)-(2+1+1)+(3+1)+(2+2)-(4)
\]
\]
有点抽象,看看就好()
\[ans=(a,b,c,d)-(a,a,b,c)-(a,b,a,c)-(a,b,c,a)-(a,b,b,c)-(a,b,c,b)-(a,b,c,c)+(a,a,a,b)+(a,a,b,a)+(a,b,a,a)+(a,b,b,b)+(a,a,b,b)+(a,b,a,b)+(a,b,b,a)-(a,a,a,a)
\]
\]
\[ans=(a,b,c,d)-(a,b,a,c)-(a,b,c,a)-(a,b,b,c)-(a,b,c,b)
\]
\]
然后变成 \(O(n\log n)\) 的偏序问题,随便做做就好了(
#include<algorithm>
#include<cstdio>
typedef unsigned ui;
typedef unsigned long long ull;
const int M=1e5+5;
ui n,a[M],px[M],sx[M],py[M],sy[M];ui V[M],BIT[M];ui len,lsh[M];
inline void Add(ui x){
++V[x];while(x<=len)++BIT[x],x+=x&-x;
}
inline ui Qry(ui x){
ui ans(0);while(x>=1)ans+=BIT[x],x^=x&-x;return ans;
}
signed main(){
ull s1(0),s2(0),ans(0);
scanf("%u",&n);
for(ui i=1;i<=n;++i)scanf("%u",a+i),lsh[++len]=a[i];
std::sort(lsh+1,lsh+len+1);len=std::unique(lsh+1,lsh+len+1)-lsh-1;
for(ui i=1;i<=n;++i)a[i]=std::lower_bound(lsh+1,lsh+len+1,a[i])-lsh;
for(ui i=1;i<=n;++i){
sx[i]=Qry(a[i]-1);
sy[i]=i-V[a[i]]-1-sx[i];
Add(a[i]);
}
for(ui i=1;i<=len;++i)BIT[i]=V[i]=0;
for(ui i=n;i>=1;--i){
px[i]=Qry(a[i]-1);
py[i]=n-i-V[a[i]]-px[i];
Add(a[i]);
}
for(ui i=1;i<=n;++i)s1+=py[i],s2+=px[i];ans=s1*s2;
for(ui i=1;i<=n;++i){
ans-=py[i]*px[i]+py[i]*sy[i]+sx[i]*px[i]+sx[i]*sy[i];
}
printf("%llu",ans);
}
最新文章
- WPF ListBox
- Centos7下搭建KVM虚拟机
- 查看lnmp 编译参数
- jumpGate部署
- 视频(其他)下载+tomcat 配置编码+图片上传限制大小
- The Wall (medium)
- unity调用c++ dll方法介绍
- 《An Industrial-Strength Audio Search Algorithm》译文
- Android 增强版百分比布局库 为了适配而扩展
- Arch Linux下韩文重叠显示
- java可变参数长度
- 【HDU1693】Eat the Trees(插头dp)
- 数据库04_SQL简单实践
- <;要做股市赢家:杨百万>;读书笔记
- linux free 理解
- With Visual Studio, Open Same File In Two Windows, Updates Reflected in Both
- 进程间通信机制(管道、信号、共享内存/信号量/消息队列)、线程间通信机制(互斥锁、条件变量、posix匿名信号量)
- P3292 [SCOI2016]幸运数字
- ubuntu sublime text 3 build 3083 license
- iPhone4 降级6.12教程 无须SHSH 不装插件 不睡死[转载] by 轻鸢
热门文章
- hitTest练习
- IM开发通信协议基础知识(一)---TCP、UDP、HTTP、SOCKET
- 编译安装haproxy
- 深入MySQL(一):MySQL的组织架构
- Python语法进阶(2)- 正则表达式
- (Unity)XML文件读写与IO文件操作类使用介绍
- LibOpenCM3(四) VSCode IDE 环境配置
- [LeetCode]1470. 重新排列数组
- .NET 6学习笔记(1)——通过FileStream实现不同进程对单一文件的同时读写
- 由浅入深--第一个MyBatis程序