2014NOIP普及组真题 1. 珠心算测验

线上OJ:

一本通:http://ybt.ssoier.cn:8088/problem_show.php?pid=1965

核心思想:

1、题目所求为"有多少个数=其他两个数之和 ",故不管5是由1+4组成,还是2+3组成,都只算一次。

2、利用 set自动去重 的功能,只要将结果丢进set,最后输出set的size即可

3、由于题目的 n 只有100,非常小,所以可以用三重循环暴力枚举直接完成

cpp 复制代码
#include <bits/stdc++.h>
#define MAXN 105
using namespace std;

set<int> s; // 利用set有自动去重的功能,只要将结果丢进set,最后输出set的size即可
int n;
int a[MAXN];

int main()
{
    cin >> n;
    for(int i = 1; i <= n; i++)  cin >> a[i];

    for(int i = 1; i <= n; i++)
        for(int j = i + 1; j <= n; j++)
            for(int k = 1; k <= n; k ++)
            {
                if(a[i]+a[j]==a[k])
                {
                    s.insert(a[k]);
                }
            }

    cout << s.size() << endl;
    return 0;
}
思考:

如果 n 的范围超过 1 0 3 10^3 103,则上述方法会超时,这是可以考虑反向枚举答案 ,因为a[i]不超过10,000,所以最终的和不超过20000。只要 建20000个桶,最后看哪些桶的结果被标记过了即可

cpp 复制代码
#include <bits/stdc++.h>
#define MAXN 105
using namespace std;

int n, ans = 0;
int a[MAXN];
int res[20005] = {0};

int main()
{
    cin >> n;
    for(int i = 1; i <= n; i++)  cin >> a[i];

    for(int i = 1; i <= n; i++)
        for(int j = i + 1; j <= n; j++)
            res[a[i] + a[j]] = 1; // 标记为计算过

    for(int i = 1; i <= n; i++)
        if(res[ a[i] ]) ans++;   // 如果a[i]数组中的值在res[i]被标记过,则ans++

    cout << ans << endl;
    return 0;
}
相关推荐
jz_ddk1 小时前
[科普] AI加速器架构全景图:从GPU到光计算的算力革命
人工智能·学习·算法·架构
曦月逸霜2 小时前
内部排序算法总结(考研向)
考研·算法·排序算法
仪器科学与传感技术博士2 小时前
Matplotlib库:Python数据可视化的基石,发现它的美
开发语言·人工智能·python·算法·信息可视化·matplotlib·图表可视化
草莓熊Lotso3 小时前
【洛谷题单】--分支结构(二)
c语言·c++·经验分享·其他·刷题
snowfoootball3 小时前
2025 蓝桥杯C/C++国B 部分题解
c语言·c++·笔记·学习·贪心算法·蓝桥杯
success3 小时前
【爆刷力扣-二叉树】层次遍历
算法
爱吃芒果的蘑菇5 小时前
使用pybind11封装C++API
开发语言·c++·python
2501_924880705 小时前
手机拍照识别中模糊场景准确率↑37%:陌讯动态适配算法实战解析
人工智能·深度学习·算法·计算机视觉·智能手机·视觉检测
lifallen6 小时前
HBase的异步WAL性能优化:RingBuffer的奥秘
大数据·数据库·分布式·算法·性能优化·apache·hbase
星期天要睡觉6 小时前
机器学习——支持向量机(SVM)实战案例
笔记·算法·支持向量机