ssl 2520 小球
生活随笔
收集整理的這篇文章主要介紹了
ssl 2520 小球
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
分析
二重循環(huán)會(huì)TLE,所以就要思考如何優(yōu)化。(研究了很久)
當(dāng)i<ji<ji<j時(shí),(i=ji=ji=j不可能,i>ji>ji>j會(huì)重復(fù))且顏色不同
那么ans+=j?ians+=j-ians+=j?i
一重循環(huán)時(shí)j的增加數(shù)量取決于i的個(gè)數(shù),而i前綴和就好了。
用兩個(gè)數(shù)組a和b,a[j]表示Ci為j時(shí)的下標(biāo)和,b[j]表示Ci為j時(shí)的個(gè)數(shù)。然后水水地到了第一。
代碼
#include <cstdio> #include <cctype> using namespace std; long long ans,a[2],b[2],n; int in(){int ans=0; char c=getchar();while (!isdigit(c)) c=getchar();while (isdigit(c)) ans=ans*10+c-48,c=getchar();return ans; } int main(){n=in();for (int i=1;i<=n;i++){ bool x=in(); a[x]+=i; b[x]++;ans+=i*b[1-x]-a[1-x];}return !printf("%lld",ans); }總結(jié)
以上是生活随笔為你收集整理的ssl 2520 小球的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: mysql 南邮ctf_南邮ctf之we
- 下一篇: 轨迹聚类之分段聚类方法总结