CF1922B Forming Triangles 题解
解题思路
显然,有以下两种选择的方法:
- 所有边一样长;
- 两条一样长的边,第三条边小于这两条边。
然后组合数计算即可。
AC 代码
#include<stdio.h>
#include<stdlib.h>
#include<algorithm>
#include <vector>
#define ll long long
#define N 300005
int n,a[N];
inline ll C3(ll x){
if(x<3) return 0ll;
return x*(x-1)*(x-2)/6ll;
}
inline ll C2(ll x){
if(x<2) return 0ll;
return x*(x-1)/2ll;
}
inline void work(){
scanf("%d",&n);
for(register int i=1;i<=n;++i)
scanf("%d",&a[i]);
std::sort(a+1,a+n+1);
std::vector<int> cnt(n+1,0);
for(register int i=1;i<=n;++i)
++cnt[a[i]];
ll ans=0,res=n;
for(register int i=n;i>=0;--i){
res-=cnt[i];
ans+=C3(cnt[i]);
ans+=C2(cnt[i])*res;
}printf("%lld\n",ans);
}
signed main(){
int T;scanf("%d",&T);
while(T--) work();
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示