这场题好弱啊qwq
先发代码再填坑
T1 bzoj4415
#include <iostream> #include <cstdio> #include <cstring> #include <cmath> #include <cstdlib> #include <algorithm> #define N 700005 using namespace std; inline int read(){ int ret=0;char ch=getchar(); while (ch<‘0‘||ch>‘9‘) ch=getchar(); while (‘0‘<=ch&&ch<=‘9‘){ ret=ret*10-48+ch; ch=getchar(); } return ret; } int n; struct BIT{ int c[N]; int lowbit(int x){return x&-x;} void load(){ memset(c,0,sizeof(c)); for (int i=1;i<=n;++i){ ++c[i]; if (i+lowbit(i)<=n) c[i+lowbit(i)]+=c[i]; } } int solve(int sum){ int x=0,now=0; for (int i=(1<<20);i;i=i>>1) if (x+i<=n&&now+c[x+i]<sum){ x+=i;now+=c[x]; } for (int i=(++x);i<=n;i+=lowbit(i)) --c[i]; return x; } } bit; int main(){ n=read(); bit.load(); int now=n,sum=n; for (int i=n;i;--i){ int x=read()%i+1; if (i-sum>=x) sum=sum+x-1; else sum=x+sum-i-1; printf("%d\n",bit.solve(sum+1)); } return 0; }
T2 bzoj4416
#include <iostream> #include <cstdio> #include <cmath> #include <cstring> #include <cstdlib> #include <algorithm> #define N 30 #define L 505 using namespace std; int n,l;char s[L]; int nxt[L][N],dp[1<<21^233]; inline int lowbit(int x){return x&-x;} bool work(){ scanf("%d%s",&n,s+1);l=strlen(s+1); if (n>21) return 0; for (int i=0;i<n;++i) nxt[l+1][i]=l+1; for (int i=l;i>=0;--i){ for (int j=0;j<n;++j) nxt[i][j]=nxt[i+1][j]; if (i) nxt[i][s[i]-‘a‘]=i; } for (int i=dp[0]=0;i<(1<<n);dp[++i]=0) for (int j=0;j<n;++j)if ((i&(1<<j))>0) dp[i]=max(dp[i],nxt[dp[i^(1<<j)]][j]); return dp[(1<<n)-1]<=l; } int main(){ int testnumber;scanf("%d",&testnumber); while (testnumber--) puts(work()?"YES":"NO"); return 0; }
T3 bzoj4417
#include <iostream> #include <cstdio> #include <cmath> #include <cstring> #include <cstdlib> #include <algorithm> #define ll long long #define P 30011 using namespace std; struct matrix{ int x,y; int a[105][105]; matrix(){} matrix(int _x,int _y):x(_x),y(_y){} matrix(int _x){ x=y=_x; memset(a,0,sizeof(a)); for (int i=1;i<=_x;++i) a[i][i]=1; } } A,B,C,D; inline matrix operator *(matrix a,matrix b){ if (a.y!=b.x) swap(a,b); matrix ret=matrix(a.x,b.y); int z=a.y; for (int i=1;i<=ret.x;++i) for (int j=1;j<=ret.y;++j){ ret.a[i][j]=0; for (int k=1;k<=z;++k) (ret.a[i][j]+=(ll)a.a[i][k]*b.a[k][j]%P)%=P; } return ret; } matrix pow(matrix x,int y){ matrix ret=matrix(x.x); while (y){ if (y&1) ret=ret*x; y/=2; x=x*x; } return ret; } int main(){ int n,m;scanf("%d%d",&n,&m); if ((--m)==1){printf("%d\n",n<=2);return 0;} A=matrix(2*n);B=matrix(2*n); for (int i=1;i<=n;++i) for (int j=max(i-1,1);j<=i+1&&j<=n;++j) ++A.a[j][i+n],++B.a[j+n][i]; int ans=0; if (m&1){ C=A*B; D=B*pow(C,m/2-1); ans=D.a[2*n][1]; D=D*C; ans=(D.a[2*n][1]-ans+P)%P; } else{ C=A*B; D=pow(C,m/2-1); ans=D.a[n][1]; D=D*C; ans=(D.a[n][1]-ans+P)%P; } printf("%d\n",ans); return 0; }
原文:http://www.cnblogs.com/wangyurzee7/p/5252312.html