洛谷P2141 [NOIP2014 普及组] 珠心算测验

[NOIP2014 普及组] 珠心算测验

题目描述

珠心算是一种通过在脑中模拟算盘变化来完成快速运算的一种计算技术。珠心算训练,既能够开发智力,又能够为日常生活带来很多便利,因而在很多学校得到普及。

某学校的珠心算老师采用一种快速考察珠心算加法能力的测验方法。他随机生成一个正整数集合,集合中的数各不相同,然后要求学生回答:其中有多少个数,恰好等于集合中另外两个(不同的)数之和?

最近老师出了一些测验题,请你帮忙求出答案。

(本题目为 2014NOIP 普及 T1)

输入格式

共两行,第一行包含一个整数 n,表示测试题中给出的正整数个数。

第二行有 n 个正整数,每两个正整数之间用一个空格隔开,表示测试题中给出的正整数。

输出格式

一个整数,表示测验题答案。

样例 #1

样例输入 #1

4
1 2 3 4

样例输出 #1

2

提示

【样例说明】

由 1+2=3,1+3=4,故满足测试要求的答案为 2。

注意,加数和被加数必须是集合中的两个不同的数。

提交程序


import java.util.*;

public class Main{
    public static void main(String[] args) {
       Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] a = new int[n];
        for (int i = 0; i < n; i++) {
            a[i] = sc.nextInt();
        }
        //利用set集合的不可重复性,消除重复的和
        Set<Integer> list = new HashSet<>();
        int count = 0;
        for (int i = 0; i < a.length; i++) {
            for (int j = i + 1; j < a.length; j++) {
                list.add(a[i] + a[j]);
            }
        }
        //遍历和与原n个正整数是否相同,即累加次数
        for (Integer integer : list) {
            for (int i = 0; i < a.length; i++) {
                if (integer == a[i]) {
                    count++;
                }
            }
        }
        System.out.println(count);
    }
}

posted @ 2022-11-24 13:55  冲冲不会啊  阅读(36)  评论(0编辑  收藏  举报