小L的多项式

博客讲述了如何处理需要计算大数次幂的问题,指出在牛客网上的一道题目中,由于x[i]可能非常大,不能直接使用 pow 函数。作者提出通过自定义函数来计算,初始思路是简单的连乘,但考虑到效率问题,引入了快速幂算法。快速幂可以显著减少计算次数,例如计算 10 的 4 次幂只需两次运算,而计算 10 的 8 次幂只需三次运算。文章最后给出了使用快速幂改进后的算法实现。
摘要由CSDN通过智能技术生成

在这里插入图片描述
牛客上的简单题,题目涉及数的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 >>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值