首页 > 其他分享 >简单封装Poly

简单封装Poly

时间:2023-01-04 16:55:05浏览次数:36  
标签:封装 int res Poly const 简单 return Deg

非常优雅的马蜂

#include <bits/stdc++.h>
typedef long long ll;typedef unsigned long long ull; typedef double db;typedef long double ldb;
#define fre(x) freopen(#x ".in","r",stdin),freopen(#x ".out","w",stdout)
#define Rep(i,a,b) for(int i=a;i<=b;++i) 
#define Dwn(i,a,b) for(int i=a;i>=b;--i)
#define pii pair<int,int>
#define mair make_pair
#define cp complex<double>
#define fir first
#define sec second
using namespace std;

const int maxn=4e6+10,Mod=998244353;

int pw(int x,int p){int res=1,base=x;while(p){if(p&1)res=1LL*res*base%Mod;base=1LL*base*base%Mod;p>>=1;}return res;}
int Inv(int x){return pw(x,Mod-2);}

int W[maxn],Cw[maxn],rev[maxn];
int deg,lg;
void Init(int len){
	deg=1,lg=0;while(deg<len)deg<<=1,++lg;
	W[0]=Cw[0]=1;int Wp=pw(3,(Mod-1)/deg),Cp=pw(Inv(3),(Mod-1)/deg);
	for(int i=1;i<deg;++i)rev[i]=(rev[i>>1]>>1)|((i&1)<<(lg-1)),W[i]=1LL*W[i-1]*Wp%Mod,Cw[i]=1LL*Cw[i-1]*Cp%Mod;
}

struct Poly{	
	vector<int>f;
	int &operator[](const int &i){return f[i];}
	int operator[](const int &i)const{return f[i];}
	int Deg(){return f.size();}
	int Deg()const{return f.size();}
	void Set(int len){f.resize(len);}
	void Adjust(){while(f.size()>1 && f.back()==0)f.pop_back();}
	void Reverse(){reverse(f.begin(),f.end());}
	void Print(){for(auto it : f)cerr<<it<<" ";cerr<<"\n";}
	void Diri(){for(int i=0;i+1<(int)f.size();++i)f[i]=1LL*f[i+1]*(i+1)%Mod;f.back()=0;}
	void Integ(){for(int i=((int)f.size())-1;i>=1;--i)f[i]=1LL*f[i-1]*::Inv(i)%Mod;f[0]=0;}
	Poly Dir(){Poly res;res.Set(Deg());for(int i=0;i+1<f.size();++i)res[i]=1LL*f[i+1]*(i+1)%Mod;return res;}
	Poly Inte(){Poly res;res.Set(Deg());for(int i=((int)f.size()-1);i>=1;--i)res[i]=1LL*f[i-1]*::Inv(i)%Mod;return res;}
	void NTT(int deg,int w[],int opt){
		Set(deg);for(int i=0;i<deg;++i)if(i<rev[i])swap(f[i],f[rev[i]]);
		for(int t=deg>>1,m=1;m<deg;m<<=1,t>>=1)for(int i=0;i<deg;i+=(m<<1))for(int j=0;j<m;++j)
		{ int x=f[i+j],y=1LL*w[t*j]*f[i+j+m]%Mod;f[i+j]=(x+y)%Mod,f[i+j+m]=(x-y+Mod)%Mod;}
		if(opt==-1){int inv=::Inv(deg);for(int i=0;i<deg;++i)f[i]=1LL*f[i]*inv%Mod;}
	}
	friend Poly operator + (const Poly &x,const Poly &y){
		Poly res; res.Set(max(x.Deg(),y.Deg()));
		for(int i=0;i<x.Deg();++i)res[i]=x[i];
		for(int i=0;i<y.Deg();++i)res[i]=(res[i]+y[i])%Mod;
		return res;
	}
	void operator += (const Poly &x){
		Set(max(Deg(),x.Deg()));
		for(int i=0;i<x.Deg();++i)f[i]=(f[i]+x[i])%Mod;
	}
	friend Poly operator - (const Poly &x,const Poly &y){
		Poly res; res.Set(max(x.Deg(),y.Deg()));
		for(int i=0;i<x.Deg();++i)res[i]=x[i];
		for(int i=0;i<y.Deg();++i)res[i]=(res[i]-y[i]+Mod)%Mod;
		return res;
	}
	void operator -= (const Poly &x){
		Set(max(Deg(),x.Deg()));
		for(int i=0;i<x.Deg();++i)f[i]=(f[i]-x[i]+Mod)%Mod;
	}
	friend Poly operator * (const Poly &x,const Poly &y){
		Poly res,A=x,B=y;
		Init(A.Deg()+B.Deg()-1);
		A.NTT(deg,W,1);B.NTT(deg,W,1);res.Set(deg);
		for(int i=0;i<deg;++i)res[i]=1LL*A[i]*B[i]%Mod;
		res.NTT(deg,Cw,-1);res.Adjust();
		return res;
	}
	void operator *= (const Poly &x){
		Poly A=x;
		Init(Deg()+A.Deg()-1);
		NTT(deg,W,1),A.NTT(deg,W,1);
		for(int i=0;i<deg;++i)f[i]=1LL*f[i]*A[i]%Mod;
		NTT(deg,Cw,-1);Adjust();
	}
	friend Poly operator / (const Poly &x,const Poly &y){
		Poly E=x,D=y;
		E.Reverse(),D.Reverse();D.Set(x.Deg()-y.Deg()+1);
		D=D.Inv();D*=E;
		D.Set(x.Deg()-y.Deg()+1); D.Reverse();
		return D;
	}
	friend pair<Poly,Poly> operator % (const Poly &x,const Poly &y){
		Poly E=x,D=y;
		E.Reverse(),D.Reverse();D.Set(x.Deg()-y.Deg()+1);
		D=D.Inv();D*=E;
		D.Set(x.Deg()-y.Deg()+1); D.Reverse();
		Poly R=x-D*y; R.Set(x.Deg()-1);
		return {D,R};
	}
	Poly Inv(){
		Poly res;res.Set(1);
		if(f.empty())return res;
		int len,lim;res[0]=::Inv(f[0]);Poly A,B;
		for(len=2;len<(Deg()<<1);len<<=1){
			A.f.assign((*this).f.begin(),(*this).f.begin()+min(len,Deg())),B=res;
			B.Set(min(len,Deg()));
			Init(A.Deg()+B.Deg()-1);A.NTT(deg,W,1),B.NTT(deg,W,1);res.Set(deg);
			for(int i=0;i<deg;++i)res[i]=((2LL-1LL*A[i]*B[i]%Mod)*B[i]%Mod+Mod)%Mod;
			res.NTT(deg,Cw,-1);
			res.Set(len);
		}
		res.Set(Deg());return res;
	}
	Poly Ln(){
		Poly res=Dir();Poly I=Inv();
		res*=I;res.Integ(); res.Set(Deg());
		return res;
	}
	Poly Exp(){
		Poly res;res.Set(1);res[0]=1;
		int len;Poly A,B;
		for(len=2;len<(Deg()<<1);len<<=1){
			res.Set(len);A=res.Ln();
			B.f.assign((*this).f.begin(),(*this).f.begin()+min(len,Deg()));
			B-=A;B[0]++;res*=B;
			res.Set(len);
		}
		res.Set(Deg());return res;
	}
	Poly Pow(int k){
		Poly res=Ln();
		for(int i=0;i<res.Deg();++i)res[i]=1LL*res[i]*k%Mod;
		return res.Exp();
	}
	Poly Sqrt(){
		Poly res;res.Set(1);res[0]=1;
		int len;Poly A,B;int inv2=::Inv(2);
		for(len=2;len<(Deg()<<1);len<<=1){
			res.Set(len);A=res.Inv();
			B.f.assign((*this).f.begin(),(*this).f.begin()+min(len,Deg()));
			A*=B;
			for(int i=0;i<len;++i)res[i]=1LL*(res[i]+A[i])*inv2%Mod;
			res.Set(len);
		}
		res.Set(Deg());return res;
	}
}F,G;
int n,m;

void solve(){ }
int main (){ ios::sync_with_stdio(false),cin.tie(0),cout.tie(0);return solve(),0; }

标签:封装,int,res,Poly,const,简单,return,Deg
From: https://www.cnblogs.com/Delov/p/16457703.html

相关文章

  • 利用javaswing+百度云图像识别接口做一个简单的动植物图像识别
    importcom.baidu.aip.imageclassify.AipImageClassify;importcom.sun.prism.PresentableState;importorg.json.JSONObject;importjava.awt.*;importjava.awt.ev......
  • 如何使用mill搭建一个最简单的chisel项目,并且成功运行?(未完成,后边再搞定)
    关于为什么使用mill而不是sbt?Well,这两个你到后边都得会的,既然ysyx默认使用mill,那就直接用mill吧参考资料:https://alvinalexander.com/scala/mill-build-tool-hello-world-......
  • 多项式封装
    推销一下基于继承的多项式封装,好多函数可以直接用vector的,不用再次封装了,省事很多另外()运算符太赞了,虽然时间是resize()的\(4\)倍,但是很好用!!,再也不用费力计算多项式的大......
  • GridView 自定义简单操作
    usingSystem;usingSystem.Data;usingSystem.Configuration;usingSystem.Collections;usingSystem.Web;usingSystem.Web.Security;usingSy......
  • S7.NET —— 简单使用
    2023-01-04 最近想写个与PLC通讯的程序,找到了S7.NET,简单记录下使用方法用途:与西门子PLC通讯流程:创建连接——读/写数据——关闭连接1.添加引用usingS7.Net;2.......
  • winform中的提示框+MSN提示封装,原生的也不错
    开发winform项目时,如果某个功能执行完成,需要告诉用户结果,比如成功还是失败?可以用提示框实现,今天就来聊聊这个不太起眼的小功能:提示框。其实net提供的提示框已经很丰富了,如......
  • spring mobile简单试用
    springmobile是spring新推出的一个用于支持移动浏览的小框架,用起来很简单,和springmvc结合也很方便。首先建立一个springmvc的工程然后,在pom.xml中添加springmobile的支......
  • dremio datastore简单说明
    datastore实际上是进行数据存储的实现(主要是配置以及元数据相关的)不少服务都使用到了此功能(namespace,catalog,user,job)实际上dremio官方对于dremio的部署(软件版,尤其......
  • Linux环境下java环境变量配置简单说明
    第一步:到jdk包的路径下tar-xvfjdk-8u121-linux-x64.tar.gz-C/usr/lib/jvm第二步:cd/usr/lib/jvmls-ls查看下 第三步:配置环境变量vim/etc/profile按键i进入插入......
  • CSV:简单格式下隐藏的那些坑
    摘要:本文将盘点处理CSV数据时我遇到的一些坑。本文分享自华为云社区《CSV—简单格式下隐藏的那些坑》,作者:aKi。前言CSV(Comma-SeparatedValues),是一种通用的、相对简单的......