题意:给一个多项式 和a数组和k,问你是否能通过改变一个ai来使得P(2)==0
an!=0&&ai<=k
思路:
因为x==2,所以如果sum[i](就是i和i之前的多项式所需改变的值ai)是奇数就显然不可能是答案。最后一个偶数既为flag
所以答案可能是0~flag
然后从先从最后一个往前跑到flag时如果当前的t+sum[i] (前边的和)小于k的话, 就一定是答案,然后枚举flag~0里边满足答案的个数就行了
#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<math.h>
#include<queue>
#include<stack>
#include<string>
#include<vector>
#include<map>
#include<set>
using namespace std;
#define mem(a,b) memset(a,b,sizeof(a))
#define lowbit(x) (x&(-x))
typedef long long LL;
#define maxn 200005
const int inf=(1<<28)-1;
int A[maxn];
LL Abs(LL x)
{
if(x<0) return -x;
return x;
}
LL sum[maxn];
int main()
{
int n;
LL k;
scanf("%d%lld",&n,&k);
for(int i=0;i<=n;++i)
scanf("%d",&A[i]);
LL t=0,flag=0;
for(int i=0;i<=n;++i)
{
t/=2;
sum[i]=t;
t+=A[i];
flag=i;
if(t%2) break;
}
for(int i=flag+1;i<=n;++i)
{
t/=2;
sum[i]=t;
t+=A[i];
}
//printf("%d\n",flag);
int ans=0;
t=0;
for(int i=n;i>=0;--i)
{
t*=2;
if(Abs(t+sum[i])<=k&&i<=flag)
ans++;
t+=A[i];
if(Abs(t)>=k) break;
}
t=0;
for(int i=0;i<=n-1;++i)
{
t/=2;
t+=A[i];
}
if(!t&&n==flag) ans--;
printf("%d\n",ans);
return 0;
}