标签:
题目:传送门
4 4 0 0 0 0 2 1 3 4 1 10 100 111 1 3
Case #1: 256 Case #2: 1 Case #3: 6 Case #4: 0
这题题意很简单,但是我比赛的时候没有做出来,当时看见几乎所有人都A了痛苦啊,就是一道简单哈希。
题意:给定一个序列,查找所有满足s[a]+s[b]+s[c]=s[d]的abcd的组数,注意,不要求abcd都不同。
分析:n<=1000,很明显O(n^3)的算法是不可能过的。式子可以转化为s[a]+s[b]=s[d]-s[c],然后复杂度就变成了O(n^2),先枚举ab,再枚举cd即可,用数组离散化。注意,因为s[a]+s[b]肯定是>=0,所以可以剪枝掉所有的s[d]-s[c]<0的情况。
#include <iostream> #include <algorithm> #include <stdio.h> #include <string.h> typedef long long ll; using namespace std; int n,a[1010],h[2000010]; ll sum; int main() { int T; scanf("%d",&T); for(int z=1;z<=T;z++) { scanf("%d",&n); sum=0; memset(h,0,sizeof(h)); for(int i=0;i<n;i++) scanf("%d",&a[i]); for(int i=0;i<n;i++) { for(int j=0;j<n;j++) if(a[i]-a[j]>=0) h[a[i]-a[j]]++; } for(int i=0;i<n;i++) { for(int j=0;j<n;j++) sum+=h[a[i]+a[j]]; } printf("Case #%d: %lld\n",z,sum); } return 0; }
标签:
原文地址:http://www.cnblogs.com/zhangmingcheng/p/4328313.html