问题:
问题描述:
有 N 个非零且各不相同的整数。请你编一个程序求出它们中有多少对相反数(a 和 -a 为一对相反数)。
输入格式:
第一行包含一个正整数 N。(1 ≤ N ≤ 500)。
第二行为 N 个用单个空格隔开的非零整数,每个数的绝对值不超过1000,保证这些整数各不相同。
输出格式:
只输出一个整数,即这 N 个数中包含多少对相反数。
样例输入:
5
1 2 3 -1 -2
样例输出:
2
思路:将数据存入数组中,进行for循环遍历,将符合条件的数组进行加操作,由于进行循环遍历时重复一次,所以除以2取得正确结果。
题解:
import java.util.*;
public class Opposite_Number {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc=new Scanner(System.in);
int number;
number=sc.nextInt();
int n[]=new int[number];
int i,j,b=0;
for(i=0;i<number;i++){
n[i]=sc.nextInt();
}
for(i=0;i<number;i++)
for(j=0;j<number;j++){
if(n[j]+n[i]==0){
b++;
}
}
b=b/2;
System.out.println(b);
sc.close();
}
}