【蓝桥杯每日一题】求和——前缀和

求和

蓝桥杯每日一题 2024-12-17 求和 前缀和

题目大意

给定 n n n 个整数 a 1 , a 2 , ... , a n a_1, a_2, \ldots, a_n a1,a2,...,an,求它们两两相乘再相加的和,即:

S = a 1 ⋅ a 2 + a 1 ⋅ a 3 + ... + a 1 ⋅ a n + a 2 ⋅ a 3 + ... + a n − 2 ⋅ a n − 1 + a n − 2 ⋅ a n + a n − 1 ⋅ a n S = a_1 \cdot a_2 + a_1 \cdot a_3 + \ldots + a_1 \cdot a_n + a_2 \cdot a_3 + \ldots + a_{n-2} \cdot a_{n-1} + a_{n-2} \cdot a_n + a_{n-1} \cdot a_n S=a1⋅a2+a1⋅a3+...+a1⋅an+a2⋅a3+...+an−2⋅an−1+an−2⋅an+an−1⋅an

解题思路

将这个求和公式转化一下就变成了 : S = a 1 ⋅ ( a 2 + a 3 + ... + a n ) + a 2 ⋅ ( a 3 + ... + a n ) + a n − 2 ⋅ ( a n − 1 + a n ) + a n − 1 ⋅ a n S = a_1 \cdot ( a_2 + a_3 + \ldots + a_n) + a_2 \cdot (a_3 + \ldots + a_n) + a_{n-2} \cdot (a_{n-1} + a_n) + a_{n-1} \cdot a_n S=a1⋅(a2+a3+...+an)+a2⋅(a3+...+an)+an−2⋅(an−1+an)+an−1⋅an

对于括号里的这些值的和就表示某个区间的前缀和。

Accepted
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

typedef long long ll;
const int N = 200000;
ll a[N],b[N];
ll n;

int main()
{
    cin>>n;
    for(int i = 1;i <= n;i++) {
        cin>>a[i];
        b[i] = b[i-1] + a[i];
    }
    ll sum = 0;
    for(int i = 1;i < n;i++) {
        sum += a[i] * (b[n]-b[i]);
    }
    cout<<sum<<endl;
    return 0;
}
思考

这道题算是前缀和的简单应用吧,学过前缀和就可以!

备注

想要一起备赛的同学可以评论区或私信留言!

相关推荐
xwz小王子18 分钟前
手术机器人登上Science Robotics:2毫米纤细手臂,从3厘米切口完成腰椎神经减压
算法·机器人
黎阳之光1 小时前
视频孪生智护供水生命线:黎阳之光赋能医疗与园区水务高质量升级
运维·物联网·算法·安全·数字孪生
Black蜡笔小新2 小时前
自动化AI算法训练服务器DLTM制造业AI质检工作站助力制造业实现AI智检
人工智能·算法·自动化
嵌入式小能手2 小时前
飞凌嵌入式ElfBoard-进程间的通信之命名管道
linux·服务器·算法
啦哈拉哈2 小时前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
csdn_aspnet2 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
诸葛务农3 小时前
道路行驶条件下电动汽车永磁电机的有效使用寿命及永磁体的失效和回收再利用(下)
java·开发语言·算法
snow@li3 小时前
AI:理解 大数据、算法、算力、电力、生成式AI、token 之间的关系
大数据·人工智能·算法
小智老师PMP3 小时前
零基础能不能考PMP?零基础专属学习路径+全套扶持体系
学习·算法·职场和发展·软件工程·求职招聘·敏捷流程
Dillon Dong3 小时前
【风电控制】FPGA采集Vdc的ADC增益系数解析——从数字码到实际电压的桥梁
算法·fpga开发·变流器·风电控制