问题描述
有 N 个非零且各不相同的整数。请你编一个程序求出它们中有多少对相反数(a 和 -a 为一对相反数)。
输入格式
第一行包含一个正整数 N。(1 ≤ N ≤ 500)。
第二行为 N 个用单个空格隔开的非零整数,每个数的绝对值不超过1000,保证这些整数各不相同。
输出格式
只输出一个整数,即这 N 个数中包含多少对相反数。
样例输入
5
1 2 3 -1 -2
样例输出
2
C语言实现:
/* 相反数 */
#include<stdio.h>
#define MAXN 500
int main(void){
int N, i, j, k, count = 0, a[MAXN];
scanf("%d",&N);
for(i = 0; i < N; i++){
scanf("%d",&a[i]); //将输入的数存入数组
}
for(j = 0; j < N; j++){
for(k = j + 1; k < N; k++){
if(a[j] == -a[k]){
count++;
}
}
}
printf("%d\n",count);
return 0;
}
Java语言实现:
import java.util.Scanner;
/** 相反数 */
public class Test2014_3_1 {
public static void main(String[] args) {
int N,i,j,k,count = 0;
int[] a = new int[500];
Scanner sc = new Scanner(System.in);
N = sc.nextInt();
for (i = 0; i < N; i++){
a[i] = sc.nextInt(); // 将输入的数存入数组
}
for (j = 0; j < N; j++){
for (k = j + 1; k < N; k++){
if (a[j] == -a[k]){
count++;
}
}
}
System.out.println(count);
}
}
Python语言实现:
# 相反数
N = int(input())
count = 0
a = [int(i) for i in input().split()] # 将输入的数存入数组
for j in range(0,N):
for k in range(j+1,N):
if a[j] == (-a[k]):
count += 1
print(count)