牛客上的简单题,题目涉及数的n次幂
题目条件很直白,咋一看不需要特殊方法就可以暴力破解,但仔细一看,如果x[i]很大,比如987654321,他的n次方会比longlong允许输入的最大数还要大,所以不能使用pow(x,n)函数,
我们要自己使用函数来算出x[i]的n次方。
值得注意的是,这道题的n很小,如果是使用以下代码求n次幂,就可以轻松过关
ll yjx(ll di,ll mi){
if(mi==0)
return 1;
ll c=di;
if(mi>0){
for(ll i=1;i<mi;i++)
c=c*di%998244353;
}
return c;
}
完整的代码如下``
#include<iostream>
using namespace std;
typedef long long ll;
ll n,a[1005],m,x[1005],sum=0,s;
const ll mod=998244353;
ll yjx(ll di,ll mi){
if(mi==0)
return 1;
ll c=di;
if(mi>0){
for(ll i=1;i<mi;i++)
c=c*di%mod;
}
return c;
}
int main(){
cin >> n;
for(int i=0;i<n+1;i++)
cin >> a[i];
cin >>