SP1296 SUMFOUR - 4 values whose sum is 0
2024-10-07 21:53:20
解题思路
四个数组一起做有点炸。先把他们合并成两个数组,然后让一个数组有序,枚举另一个数组的元素,二分即可。时间复杂度\(O(n^2logn^2)\)
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
const int MAXN = 4005;
inline int rd(){
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)) {f=ch=='-'?0:1;ch=getchar();}
while(isdigit(ch)) {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
return f?x:-x;
}
int A[MAXN*MAXN],B[MAXN*MAXN],n,a[MAXN],b[MAXN],c[MAXN],d[MAXN];
int num[MAXN*MAXN],cnt,cnt2,cpy[MAXN*MAXN];
long long ans;
int main(){
n=rd();int x,y,w,z;
for(int i=1;i<=n;i++)
a[i]=rd(),b[i]=rd(),c[i]=rd(),d[i]=rd();
for(register int i=1;i<=n;i++)
for(register int j=1;j<=n;j++) A[++cnt]=a[i]+b[j],B[cnt]=c[i]+d[j];
sort(A+1,A+1+cnt);A[0]=(1<<28)+1;
for(register int i=1;i<=cnt;i++){
if(A[i]==A[i-1]) num[cnt2]++;
else cpy[++cnt2]=A[i],num[cnt2]=1;
}
// for(int i=1;i<=cnt2;i++) cout<<cpy[i]<<" ";
// A[++cnt2]=1;A[++cnt2]=2;A[++cnt2]=8;B[++cnt]=1;B[++cnt]=-2;B[++cnt]=-8;
for(register int i=1;i<=cnt;i++) {
x=lower_bound(cpy+1,cpy+1+cnt2,-B[i])-cpy;
// cout<<x<<endl;
if(cpy[x]==-B[i]) ans+=num[x];
}
printf("%lld\n",ans);
return 0;
}
最新文章
- 数据预处理中归一化(Normalization)与损失函数中正则化(Regularization)解惑
- First glance in Go
- mysql添加外键错误
- [sicp]huffman编码的实现 @ Scheme
- HDU 4036 存疑题目,数论 难度:1
- Android牟利之道(一)--界面嵌入有米广告
- mysql基础知识(5)--视图
- Spring MVC 教程
- 原生sql语句执行
- Struts2学习笔记(一) Struts2配置文件的配置
- informix建临时表索引
- 配置webpack.config.js中的文件
- ArcGIS Pro开发Web3D应用(3)——Server/Portal授权服务开发
- Keepalived+Haproxy高可用负载均衡群集
- etcd集群的搭建
- Android漏洞——将Android恶意代码隐藏在图片中
- vue里面使用Velocity.js
- [Canvas]走近的女孩
- C语言 &#183; C++中map的用法详解
- <;<;、|=、&;的小例子