博客
关于我
201403-1 相反数 ccf
阅读量:249 次
发布时间:2019-03-01

本文共 787 字,大约阅读时间需要 2 分钟。

为了解决这个问题,我们需要编写一个程序来统计给定整数列表中相反数对的数量。相反数对指的是像(a, -a)这样的数对。

方法思路

为了高效地解决这个问题,我们可以采用以下步骤:

  • 读取输入数据:首先读取输入的整数数量N,然后读取这些整数。
  • 统计绝对值出现次数:创建一个数组来记录每个绝对值的出现次数。由于绝对值范围不超过1000,因此数组的大小可以设为1001。
  • 更新计数:遍历每个整数,取其绝对值,并更新对应的计数器。
  • 计算相反数对数量:遍历计数器数组,统计出现次数为2的绝对值数量。每个这样的绝对值对应一个相反数对。
  • 解决代码

    #include 
    using namespace std;int main() { int a[1001] = {0}; int n; cin >> n; for (int i = 0; i < n; ++i) { int x; cin >> x; a[abs(x)]++; } int cnt = 0; for (int i = 1; i <= 1000; ++i) { if (a[i] == 2) { cnt++; } } cout << cnt << endl; return 0;}

    代码解释

  • 读取输入:使用cin读取整数N,然后读取N个整数。
  • 统计绝对值:使用一个数组a来记录每个绝对值的出现次数。对于每个整数x,取其绝对值,并将对应的计数器a[abs(x)]加1。
  • 计算相反数对:遍历数组a,对于每个绝对值,如果其出现次数为2,则表示有一个相反数对。将这样的情况计数。
  • 输出结果:最后输出相反数对的总数。
  • 通过这种方法,我们能够高效地统计并输出相反数对的数量。

    转载地址:http://tzbx.baihongyu.com/

    你可能感兴趣的文章
    Quartz入门看这一篇文章就够了
    查看>>
    POI解析Excel【poi的坑——空行处理】
    查看>>
    POI:POI+JXL实现xls文件添加水印
    查看>>
    POI:POI实现docx文件添加水印
    查看>>
    POJ 1006
    查看>>
    Quartz中时间表达式的设置-----corn表达式
    查看>>
    poj 1035
    查看>>
    POJ 1061 青蛙的约会 (扩展欧几里得)
    查看>>
    Quartz2.2.1简单使用
    查看>>
    POJ 1080 Human Gene Functions(DP:LCS)
    查看>>
    Quant 开源项目教程
    查看>>
    POJ 1088 滑雪
    查看>>
    POJ 1095 Trees Made to Order
    查看>>
    POJ 1113 Wall(计算几何--凸包的周长)
    查看>>
    poj 1125Stockbroker Grapevine(最短路)
    查看>>
    Qualitor processVariavel.php 未授权命令注入漏洞复现(CVE-2023-47253)
    查看>>
    poj 1151 (未完成) 扫描线 线段树 离散化
    查看>>
    POJ 1151 / HDU 1542 Atlantis 线段树求矩形面积并
    查看>>
    poj 1163 数塔
    查看>>
    POJ 1177 Picture(线段树:扫描线求轮廓周长)
    查看>>