제출 #548419

#제출 시각아이디문제언어결과실행 시간메모리
548419MilosMilutinovicSnake Escaping (JOI18_snake_escaping)C++14
22 / 100
959 ms24164 KiB
#include <bits/stdc++.h> using namespace std; #define pb push_back const int N=(1<<20)+5; const int M=1600050; const int Q=1000050; int l,n,q,lst[M],pw[20],ans[Q],dp[M],msk[N],qmask[Q],omask[Q],qv[Q]; char s[N],qs[25]; void calc(){ pw[0]=1; for(int i=1;i<14;i++)pw[i]=pw[i-1]*3; for(int i=0;i<M;i++){ vector<int> bits; int x=i; while(x>0)bits.push_back(x%3),x/=3; lst[i]=-1; for(int j=0;j<bits.size();j++)if(bits[j]==2)lst[i]=j; } } void BruteForce(){ memset(dp,0,sizeof *dp); for(int i=0;i<n;i++){ int sum=0,x=i,b=0; while(x>0)sum+=(x%2)*pw[b++],x/=2; dp[sum]+=(int)(s[i]-'0'); } for(int i=0;i<M;i++)if(lst[i]!=-1){ dp[i]+=dp[i-2*pw[lst[i]]]; dp[i]+=dp[i-pw[lst[i]]]; } while(q--){ scanf("%s",qs); int sum=0; for(int i=0;i<l;i++)sum+=(qs[i]=='0'?0:(qs[i]=='1'?1:2))*pw[l-i-1]; printf("%i\n",dp[sum]); } } int main(){ scanf("%i%i",&l,&q); scanf("%s",s); n=(1<<l),calc(); if(l<=13){ BruteForce(); return 0; } for(int i=0;i<n;i++){ vector<int> bits; int x=i; while(x>0)bits.pb(x%2),x/=2; while(bits.size()<l)bits.pb(0); msk[i]=0; for(int j=7;j<l;j++)msk[i]+=bits[j]*pw[j-7]; } for(int i=1;i<=q;i++){ scanf("%s",qs); qv[i]=0; for(int j=7;j<l;j++)qv[i]+=(qs[j]=='0'?0:(qs[j]=='1'?1:2))*pw[j-7]; qmask[i]=0; for(int b=0;b<7;b++)if(qs[b]!='0')qmask[i]+=(1<<b); for(int b=0;b<7;b++)if(qs[b]=='1')omask[i]+=(1<<b); } for(int i=0;i<128;i++){ for(int j=0;j<M;j++)dp[j]=0; for(int j=0;j<(1<<(l-7));j++)dp[msk[(j<<7)+i]]+=(int)(s[(j<<7)+i]-'0'); for(int j=0;j<M;j++)if(lst[j]!=-1){ dp[j]+=dp[j-2*pw[lst[j]]]; dp[j]+=dp[j-pw[lst[j]]]; } for(int j=1;j<=q;j++)if((qmask[j]&i)==i&&(omask[j]|i)==i)ans[j]+=dp[qv[j]]; } for(int i=1;i<=q;i++)printf("%i\n",ans[i]); return 0; }

컴파일 시 표준 에러 (stderr) 메시지

snake_escaping.cpp: In function 'void calc()':
snake_escaping.cpp:18:16: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   18 |   for(int j=0;j<bits.size();j++)if(bits[j]==2)lst[i]=j;
      |               ~^~~~~~~~~~~~
snake_escaping.cpp: In function 'int main()':
snake_escaping.cpp:51:20: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   51 |   while(bits.size()<l)bits.pb(0);
      |         ~~~~~~~~~~~^~
snake_escaping.cpp: In function 'void BruteForce()':
snake_escaping.cpp:33:8: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   33 |   scanf("%s",qs);
      |   ~~~~~^~~~~~~~~
snake_escaping.cpp: In function 'int main()':
snake_escaping.cpp:40:7: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   40 |  scanf("%i%i",&l,&q);
      |  ~~~~~^~~~~~~~~~~~~~
snake_escaping.cpp:41:7: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   41 |  scanf("%s",s);
      |  ~~~~~^~~~~~~~
snake_escaping.cpp:56:8: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   56 |   scanf("%s",qs);
      |   ~~~~~^~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...