当前位置:   article > 正文

蓝桥杯2022省A题C

蓝桥杯2022省A题C

题目链接:https://www.luogu.com.cn/problem/P8772

我是在洛谷里做到这题的。

因为刚接触算法在练习前缀和,我直接再洛谷上搜索了关于前缀和的题看到这个题。

由于我一开始就知道这题要用前缀和做,所以我做起来就不难了,关键是怎么找到里面运用了前缀和的地方。

题目只给了一个式子,我们首先看不到任何破解之法,就可以带入特定的值,就像题中的案例带入的是4,将4带入后写出完整的式子是

s = a1*a2 + a1*a3 + a1*a4

  + a2*a3 + a2* a4

  +a3*a4

将公因式提取出来就是

s = a1*(a2 + a3 + a4)

+ a2*(a3 + a4)

+a3*a4

可以看到括号内就是一个前缀和的形式,这样就和前缀和联系起来了。

但是说实话,我还是不清楚怎么一看到题目就知道要运用到前缀和,如果有网友知道的话可以在评论区告知一声吗?提前说声谢谢啦。

我用的是java写的,代码如下

  1. import java.util.*;
  2. public class Main{
  3. public static void main(String[] args) {
  4. Scanner sc = new Scanner(System.in);
  5. int n = sc.nextInt();
  6. int[] a = new int[n + 10];
  7. long[] s = new long[n + 10];
  8. long sum = 0;
  9. for(int i = 1; i <= n; i++){
  10. a[i] = sc.nextInt();
  11. s[i] = s[i - 1] + a[i];
  12. }
  13. for(int i = 1; i <= n; i++){
  14. sum += a[i] * (s[n] - s[i]);
  15. }
  16. System.out.println(sum);
  17. }
  18. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/476219
推荐阅读
相关标签
  

闽ICP备14008679号