标签:i++ 打表 cst ret 中值滤波 noip 数学题 last 规律
对于这样看起来不像什么算法也没什么知识点的题,一脸懵逼的话不是手推规律就是打表找规律.........
当然还有一些超出你能力之外的数学题......
#include <cstdio> const int N=500010; int n,ans,A[N]; inline int Max(int x,int y){ return x>y?x:y; } int main(){ scanf("%d",&n); int last,now,P=0; for(int i=1;i<=n;i++){ scanf("%d",&now); if(i!=1&&now==last){ int len=i-P-1; ans=Max(ans,((len+1)>>1)-1); if(len&1){ for(int j=P+1;j<i;j++) A[j]=now; }else{ for(int j=P+1;j<=P+(len>>1);j++) A[j]=now^1; for(int j=P+(len>>1)+1;j<i;j++) A[j]=now; } P=i-1; } last=now; } int i=n+1; int len=i-P-1; ans=Max(ans,((len+1)>>1)-1); if(len&1){ for(int j=P+1;j<i;j++) A[j]=now; }else{ for(int j=P+1;j<=P+(len>>1);j++) A[j]=now^1; for(int j=P+(len>>1)+1;j<i;j++) A[j]=now; } printf("%d\n",ans); for(i=1;i<=n;i++) printf("%d ",A[i]); return 0; }
标签:i++ 打表 cst ret 中值滤波 noip 数学题 last 规律
原文地址:http://www.cnblogs.com/TSHugh/p/7354542.html