ssl 2520 小球
生活随笔
收集整理的這篇文章主要介紹了
ssl 2520 小球
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
分析
二重循環(huán)會TLE,所以就要思考如何優(yōu)化。(研究了很久)
當(dāng)i<ji<ji<j時,(i=ji=ji=j不可能,i>ji>ji>j會重復(fù))且顏色不同
那么ans+=j?ians+=j-ians+=j?i
一重循環(huán)時j的增加數(shù)量取決于i的個數(shù),而i前綴和就好了。
用兩個數(shù)組a和b,a[j]表示Ci為j時的下標(biāo)和,b[j]表示Ci為j時的個數(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 小球的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql 南邮ctf_南邮ctf之we
- 下一篇: 轨迹聚类之分段聚类方法总结