zoukankan      html  css  js  c++  java
  • CCF模拟题 相反数

    相反数

    时间限制: 1.0s
    内存限制: 256.0MB
    问题描述
      有 N 个非零且各不相同的整数。请你编一个程序求出它们中有多少对相反数(a 和 -a 为一对相反数)。
     
    输入格式
      第一行包含一个正整数 N。(1 ≤ N ≤ 500)。
      第二行为 N 个用单个空格隔开的非零整数,每个数的绝对值不超过1000,保证这些整数各不相同。
     
    输出格式
      只输出一个整数,即这 N 个数中包含多少对相反数。
     
    样例输入
    5
    1 2 3 -1 -2
     
    样例输出
    2
     
    解题:。。。
     1 #include <bits/stdc++.h>
     2 #define LL long long
     3 using namespace std;
     4 const int maxn = 1010;
     5 int positive[maxn],negative[maxn],n,tmp;
     6 int main(){
     7     while(~scanf("%d",&n)){
     8         LL ans = 0;
     9         memset(positive,0,sizeof(positive));
    10         memset(negative,0,sizeof(negative));
    11         for(int i = 0; i < n; ++i){
    12             scanf("%d",&tmp);
    13             if(tmp < 0) negative[-tmp]++;
    14             if(tmp > 0) positive[tmp]++;
    15         }
    16         for(int i = 0; i < maxn; ++i)
    17             ans += positive[i]*negative[i];
    18         printf("%I64d
    ",ans);
    19     }
    20     return 0;
    21 }
    View Code
  • 相关阅读:
    java Set(集合)
    java Stack(栈)
    java LinkedList(链表)
    简单的maven配置
    Linux下如何查找.sh后缀的文件
    linux 下shell中if的“-e,-d,-f”是什么意思
    linux重定向
    shell中$0,$?,$!等的特殊用法
    向shell脚本中传入参数
    mysql索引
  • 原文地址:https://www.cnblogs.com/crackpotisback/p/4355820.html
Copyright © 2011-2022 走看看