题目链接:
http://codeforces.com/contest/658/problem/D
题意:
给定合法多项式,改变一项的系数,使得P(2)=0,问有多少种方法?
分析:
暴力求和然后依次试一试肯定不行啦~
仔细想想,多项式和为0,就是说存在某个
那我们就从最小的开始看。把系数依次向后移。
如果系数
如果某个
最后倒着算一遍,算出对于每个位置,可以抵消后面的数的系数,然后。。。减一下他自己。。。就可以了。。。。
然后注意一下倒着求和过程中res的绝对值大于INF的情况,直接break。
代码:
#include <cstdio>
const int maxn = 200005, INF = 1e18;
long long t[maxn],a[maxn], b[maxn];
int main (void)
{
int n, k;
long long res = 0;
scanf("%d%d",&n, &k);
for(int i = 0; i <= n; i++){
scanf("%I64d",&a[i]);
}
b[n] = a[n];
int flag;
for(int i = 0; i < n; i++){
int tmp = b[i] + a[i] ;
b[i + 1] += tmp / 2ll;
b[i] = tmp % 2ll;
}
for(int i = 0; i <= n; i++){
if(b[i]){flag = i; break;}//记录
}
int cnt = 0;
for(int i = n; i >= 0; i--){
res = res * 2ll + b[i];
if(res > INF || res < -INF )break;
if(i <= flag){
int ans = a[i] - res;
if(ans >= -k && ans <= k && (ans != 0 || i != n)){
cnt++;
}
}
}
printf("%d
", cnt);
}
/*
5 5
0 -4 -2 -2 0 5
*/
智商压制,想的有点久。。。不过还是涨姿势!