相反数
时间限制:
1.0s
内存限制:
256.0MB
问题描述
有 N 个非零且各不相同的整数。请你编一个程序求出它们中有多少对相反数(a 和 -a 为一对相反数)。
输入格式
第一行包含一个正整数 N。(1 ≤ N ≤ 500)。
第二行为 N 个用单个空格隔开的非零整数,每个数的绝对值不超过1000,保证这些整数各不相同。
输出格式
只输出一个整数,即这 N 个数中包含多少对相反数。
样例输入
5
1 2 3 -1 -2
样例输出
2
解题:。。。
1 #include
2 #define LL long long
3 using namespace std;
4 const int maxn = 1010;
5 int positive[maxn],negative[maxn],n,tmp;
6 int main(){
7 while(~scanf("%d",&n)){
8 LL ans = 0;
9 memset(positive,0,sizeof(positive));
10 memset(negative,0,sizeof(negative));
11 for(int i = 0; i < n; ++i){
12 scanf("%d",&tmp);
13 if(tmp < 0) negative[-tmp]++;
14 if(tmp > 0) positive[tmp]++;
15 }
16 for(int i = 0; i < maxn; ++i)
17 ans += positive[i]*negative[i];
18 printf("%I64d\n",ans);
19 }
20 return 0;
21 }
时间: 03-20