题目给出一个多项式,然后给出q个询问,每个询问求指数部分是P对应的系数是多少。
将式子展开,发现非出现合并项,也就是说展开的式子对应的每个项是唯一的。那么对于某个项P,P肯定是由多个二进制相加得来,那么就肯定能分成多个二进制的数,于是根据P枚举P的二进制的每一位,是1就乘上对应的项。
#include<iostream>
#include<math.h>
#include<stdio.h>
#include<algorithm>
#include<string.h>
#include<vector>
#include<queue>
#include<map>
#include<set>
#define B(x) (1<<(x))
using namespace std;
typedef long long ll;
void cmax(int& a,int b){ if(b>a)a=b; }
void cmin(int& a,int b){ if(b<a)a=b; }
void cmax(ll& a,ll b){ if(b>a)a=b; }
void cmin(ll& a,ll b){ if(b<a)a=b; }
void add(int& a,int b,int mod){ a=(a+b)%mod; }
void add(ll& a,ll b,ll mod){ a=(a+b)%mod; }
const int oo=0x3f3f3f3f;
const int MOD=2012;
const int maxn=2000;
int a[maxn];
int main(){
//freopen("E:\\read.txt","r",stdin);
int T,n,q,ans,cnt;
ll P;
scanf("%d",&T);
while(T--){
scanf("%d",&n);
memset(a,0,sizeof a);
for(int i=0;i<n;i++)scanf("%d",&a[i]);
scanf("%d",&q);
while(q--){
scanf("%lld",&P);
ans=1,cnt=0;
while(P){
if(P&1) ans=(ans*a[cnt])%MOD;
P>>=1;
cnt++;
}
printf("%d\n",ans);
}
}
return 0;
}