求和蓝桥杯省赛

文章讲述了在处理一个计算数列中每个数与其他数相乘的乘积之和的问题时,初次尝试的代码出现了超时情况。通过改进算法,将每个数与所有其他数相乘改为计算每个数与剩余数之和的乘积并除以2,成功解决了超时问题,提高了效率。
摘要由CSDN通过智能技术生成

题目

在这里插入图片描述

分析

就很简单,按题目逻辑每个数与其他数相乘乘积之和。

代码

第一次失败代码

#include <iostream>
using namespace std;
long long n,sum;
long long ans;
int a[200010];
int main()
{
  cin >> n;
  for(long long i = 1; i <= n; i++)
  {
    cin >> a[i];
    for(long long j = 1; j < i; j++)
    {
      ans += a[i] * a[j];
    }
  }
 
  cout << ans;
  // 请在此输入您的代码
  return 0;
}

这个代码系统显示四个案例超时。

第二次改进代码

#include <iostream>
using namespace std;
long long n,sum;
long long ans;
int a[200010];
int main()
{
  cin >> n;
  for(long long i = 1; i <= n; i++)
  {
    cin >> a[i];
    sum += a[i];
  }
  for(long long i = 1; i <= n; i++)
  {
    ans += a[i] * (sum -a[i]);    //得到每个数与其他数之和相乘乘积之和 是答案的两倍
  }
  cout << ans/2;    //记得除以2
  // 请在此输入您的代码
  return 0;
}

小结

简单题也尽量用好一点的方法。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

粥旖跌

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值