天天看点

1305 Pairwise Sum and Divide

1305 Pairwise Sum and Divide

题目来源: HackerRank

基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题

有这样一段程序,fun会对整数数组A进行求值,其中Floor表示向下取整:

fun(A)

    sum = 0

    for i = 1 to A.length

        for j = i+1 to A.length

            sum = sum + Floor((A[i]+A[j])/(A[i]*A[j])) 

    return sum

给出数组A,由你来计算fun(A)的结果。例如:A = {1, 4, 1},fun(A) = [5/4] + [2/1] + [5/4] = 1 + 2 + 1 = 4。

Input

第1行:1个数N,表示数组A的长度(1 <= N <= 100000)。
第2 - N + 1行:每行1个数A[i](1 <= A[i] <= 10^9)。      

Output

输出fun(A)的计算结果。      

Input示例

3
1 4 1      

Output示例

4      

题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1305

分析:看大佬的分析,才知道,本人一直超时!不说了,统计1的个数和2的个数,有多少1就加一个1,有多少个2就是n*(n-1)/2!

下面给出AC代码:

1 #include <bits/stdc++.h>
 2 using namespace std;
 3 int main()
 4 {
 5     int n;
 6     int a[100005];
 7     while(scanf("%d",&n)!=EOF)
 8     {
 9         for(int i=1;i<=n;i++)
10             scanf("%d",&a[i]);
11             sort(a+1,a+1+n);
12             int c1=0,c2=0,c3=0;
13             for(int i=1;i<=n;i++)
14             {
15                 if(a[i]==1)
16                  c1++;
17                  else if(a[i]==2)
18                         c2++;
19                  else c3++;
20             }
21             int ans=c1*(c1+c2+c3-1)+c2*(c2-1)/2;
22             printf("%d\n",ans);
23     }
24     return 0;
25 }      

作  者:Angel_Kitty

出  处:https://www.cnblogs.com/ECJTUACM-873284962/

关于作者:阿里云ACE,目前主要研究方向是Web安全漏洞以及反序列化。如有问题或建议,请多多赐教!

版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。

特此声明:所有评论和私信都会在第一时间回复。也欢迎园子的大大们指正错误,共同进步。或者直接私信我

声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是作者坚持原创和持续写作的最大动力!

欢迎大家关注我的微信公众号IT老实人(IThonest),如果您觉得文章对您有很大的帮助,您可以考虑赏博主一杯咖啡以资鼓励,您的肯定将是我最大的动力。thx.

1305 Pairwise Sum and Divide

我的公众号是IT老实人(IThonest),一个有故事的公众号,欢迎大家来这里讨论,共同进步,不断学习才能不断进步。扫下面的二维码或者收藏下面的二维码关注吧(长按下面的二维码图片、并选择识别图中的二维码),个人QQ和微信的二维码也已给出,扫描下面👇的二维码一起来讨论吧!!!

1305 Pairwise Sum and Divide

欢迎大家关注我的Github,一些文章的备份和平常做的一些项目会存放在这里。