20210810A

这篇博客介绍了一道编程题目,要求计算n个小球按照颜色排列后的距离之和。每个小球颜色为0或1,距离定义为|i-j|*(ai-aj)。博主提供了30%、40%、100%的数据范围限制,并给出了O(n)复杂度的解题思路,通过维护0和1的数量以及它们的贡献来优化算法。
摘要由CSDN通过智能技术生成

题目描述

n个小球排成一列,第i个小球颜色为ai
定义小球i与j的距离为 | ( i - j ) * ( a i - a j ) |
求所有小球间距离之和
i 与 j 和 j 与 i 不必重复计算

输入

第一行一个n
第二行给出a1,a2,…,an-1,an

输出

按照题目要求作答

输入样例

5
0 1 1 0 1

输出样例

11

说明

30%: n<=10000
另外40%:n<=100000
100%:n<=1000000,0<=ai<=1

题解:

再输入中处理,当队列中加入一个数 0 or 1

而其的贡献就是其前面的所有与其相反(若本数是 0 则相反数是 1 )的数的位置与其位置的差

因为若两数相同,则 ( a i - a j ) = 0 则不会产生贡献

那就可以实现O ( n ) 了,对于 1 ~ i 这段区间,要记录有多少个 0 ,1 ,及当前 0 ,1产生了多少的贡献

再在每次 i + 1 后将其二者的贡献分别加上其的数量,并修改 0 ,1 的数量

Code

#include <algorithm>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值