VK Cup 2016 - Round 1 (Div. 2 Edition) D. Bear and Polynomials

题意:给一个多项式这里写图片描述 和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;
}

你可能感兴趣的:(VK Cup 2016 - Round 1 (Div. 2 Edition) D. Bear and Polynomials)