互不相同,太困难啦!!!!!!

考虑可以相同的情况。可以容斥。

\[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);
}

最新文章

  1. WPF ListBox
  2. Centos7下搭建KVM虚拟机
  3. 查看lnmp 编译参数
  4. jumpGate部署
  5. 视频(其他)下载+tomcat 配置编码+图片上传限制大小
  6. The Wall (medium)
  7. unity调用c++ dll方法介绍
  8. 《An Industrial-Strength Audio Search Algorithm》译文
  9. Android 增强版百分比布局库 为了适配而扩展
  10. Arch Linux下韩文重叠显示
  11. java可变参数长度
  12. 【HDU1693】Eat the Trees(插头dp)
  13. 数据库04_SQL简单实践
  14. &lt;要做股市赢家:杨百万&gt;读书笔记
  15. linux free 理解
  16. With Visual Studio, Open Same File In Two Windows, Updates Reflected in Both
  17. 进程间通信机制(管道、信号、共享内存/信号量/消息队列)、线程间通信机制(互斥锁、条件变量、posix匿名信号量)
  18. P3292 [SCOI2016]幸运数字
  19. ubuntu sublime text 3 build 3083 license
  20. iPhone4 降级6.12教程 无须SHSH 不装插件 不睡死[转载] by 轻鸢

热门文章

  1. hitTest练习
  2. IM开发通信协议基础知识(一)---TCP、UDP、HTTP、SOCKET
  3. 编译安装haproxy
  4. 深入MySQL(一):MySQL的组织架构
  5. Python语法进阶(2)- 正则表达式
  6. (Unity)XML文件读写与IO文件操作类使用介绍
  7. LibOpenCM3(四) VSCode IDE 环境配置
  8. [LeetCode]1470. 重新排列数组
  9. .NET 6学习笔记(1)——通过FileStream实现不同进程对单一文件的同时读写
  10. 由浅入深--第一个MyBatis程序