NTT入门 开拓者的卓识

news2024/11/25 10:23:58

link

大意:

给定一个长度为n的数组a
\forall i \in [1,n],求[1,n]的k阶子段和

我们定义k阶子段和如下:
 

思路:

这个k阶字段和,就是在k-1阶的基础上,再讲所有k-1阶的子段和都相加得到k阶子段和

k是很大的,所以我们很自然地想到按每一个数字的贡献来求总和:

一阶子段和[l,r]就是区间前缀和,ai有贡献当且仅当i在区间内部,贡献为1

二阶子段和[l,r]就是在找l',r',使得l<=l'<=i<=r'<=r,ai的贡献就是这样的l',r'的对数

以此类推,我们的k阶字段和就是在区间[l,r]内找到满足条件的l',r',使得有k个区间包含它们对应区间。换句话说,是要在区间内找到k-1对包含i的子区间,并且它们是嵌套的关系(可以相等)

lk​=1⩽lk−1​⩽lk−2​⩽…⩽l1​⩽i⩽r1​⩽…⩽rk−1​⩽rk

不难发现区间的左右边界互不影响。

所以我们考虑一下在一个长度为i的区间里放k-1个数的方案数,其中这k-1个数可以取等。这就是一个经典的隔板法,方案数就是C(i+k-2,k-1)。或者我们也可以这样考虑:
枚举出现过的数字的个数x,然后就是将k-1个数分成x块的方案数

就是\sum_{i=1}^{x}\binom{x}{i}\binom{k-1-1}{i-1},这可以转化为一个范德蒙德卷积(i=0时值为0),化简之后就是上式。

这其实就是在i点左侧找k-1个数的方案数,那么右侧找k-1个数也是同理

所以如果当前区间右界是r的话,我们的答案就是

ans_r=\sum_{i=1}^{r}a_i*\binom{i+k-2}{k-1}\binom{r-i+k-1}{k-1}

这个复杂度是n^2的

我们考虑优化:

不难发现,i+k-2+r-i+k-1是一个常值,这也就意味着我们可以使用ntt优化

p(i)=\binom{i+k-2}{k-1}

则原式化简如下:ans_r=\sum_{i=1}^{r}a_i*p(i+k-2)*p(r-i+k-1)

我们令f(i)=a_i*p(i+k-2),g(i)=p(i+k-1)

则原式化简如下:ans_r=\sum_{i=1}^{r}f(i)*g(r-i)

这样就是一个标准的卷积了

另外,组合数预处理的话,因为k很大,而且我们只用求以k-1为底的组合数,所以可以递推来求组合数

code

#include<bits/stdc++.h>
using namespace std;
#define ll long long
//#define int ll
#define endl '\n'
const ll N=1e5+10;
const ll mod=998244353;
ll G=3,invG;
ll n,k;
ll mas[N];
ll f[N<<2],g[N<<2],inv[N];
ll limit,L;
ll R[N<<2];
ll Invv;//inv(limit)
ll ksm(ll x,ll y)
{
    ll ans=1;
    while(y)
    {
        if(y&1) ans=ans*x%mod;
        x=x*x%mod;
        y>>=1;
    }
    return ans;
}
ll invv(ll x)
{
    return ksm(x,mod-2);
}
void init(ll x)
{
    invG=invv(G);
    limit=1,L=0;
    while(limit<=x)
    {
        limit<<=1;
        L++;
    }
    for(ll i=0;i<limit;++i) R[i]=(R[i>>1]>>1)|((i&1)<<(L-1));
        Invv=invv(limit);
}
void ntt(ll *a,ll len,ll ty)
{

    for(int i=0;i<len;++i) if(R[i]>i) swap(a[i],a[R[i]]);
    for(int k=1;k<len;k<<=1)
    {
        ll d=ksm((ty==1)?G:invG,(mod-1)/(k<<1));
        for(int i=0;i<len;i+=(k<<1))
        {
            for(int j=i,g=1;j<i+k;++j,g=(g*d)%mod)
            {
                ll Nx=a[j],Ny=((a[j+k]*g)%mod);
                a[j]=(Nx+Ny)%mod;
                a[j+k]=((Nx-Ny)%mod+mod)%mod;
            }
        }
    }
    if(ty!=1)
    {
        for(int i=0;i<=len;++i) a[i]=a[i]*Invv%mod;
    }
}
void cinit()
{
    inv[1]=1;
    for(int i=2;i<=n;++i) inv[i]=(mod-mod/i)*inv[mod%i]%mod;
    g[0]=1;
    for(int i=1;i<=n;++i) g[i]=g[i-1]*(i+k-1)%mod*inv[i]%mod;
    for(int i=1;i<=n;++i) f[i]=mas[i]*g[i-1]%mod;
}
void solve()
{
    cin>>n>>k;
    for(int i=1;i<=n;++i) cin>>mas[i];
    cinit();
    init(n+n);

    ntt(f,limit,1);ntt(g,limit,1);
    for(int i=0;i<=limit;++i) f[i]=f[i]*g[i]%mod;

    ntt(f,limit,0);
    for(int i=1;i<=n;++i) cout<<f[i]<<" ";
    cout<<endl;

}
signed main()
{
    ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    solve();
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/472054.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【C++学习】unordered_map和unordered_set的使用和封装

&#x1f431;作者&#xff1a;一只大喵咪1201 &#x1f431;专栏&#xff1a;《C学习》 &#x1f525;格言&#xff1a;你只管努力&#xff0c;剩下的交给时间&#xff01; unordered_map和unordered_set &#x1f9e2;unordered_map/set&#x1f52e;性能比较&#x1f52e;成…

Python采集二手车数据信息实现数据可视化展示

前言 嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 环境使用&#xff1a; Python 3.8 Pycharm 专业版是付费的 <文章下方名片可获取魔法永久用~> 社区版是免费的 模块使用&#xff1a; 第三方模块 需要安装的 requests >>> pip install requests p…

分享5款让生活和工作变得更加高效的软件

随着科技的发展,我们的生活和工作变得越来越数字化和自动化。许多实用软件应运而生,它们不仅简化了我们的生活,也使工作变得更加高效。这里我们来介绍5款非常实用的软件工具。 1.安全擦除工具——Secure Eraser Secure Eraser是一款可以安全删除数据的工具&#xff0c;它使用…

基于铜锁,在前端对登录密码进行加密,实现隐私数据保密性

本文将基于 铜锁&#xff08;tongsuo&#xff09;开源基础密码库实现前端对用户登录密码的加密&#xff0c;从而实现前端隐私数据的保密性。 首先&#xff0c;铜锁密码库是一个提供现代密码学算法和安全通信协议的开源基础密码库&#xff0c;在中国商用密码算法&#xff0c;例…

京东T7架构师用470页就把微服务架构原理与开发实战文档讲完了

前言 最近几年软件开发方法层出不穷&#xff0c;微服务作为一种主流的架构模式一直热度不减。 为了帮助广大程序员们更好更快地理解微服务的概念&#xff0c;学习微服务在项目中的实践&#xff0c;本文全面阐述了微服务架构模式的特点、架构思路、设计理念、技术框架及具体的…

根据cadence设计图学习硬件知识day07 了解一些芯片

1.LC0502N &#xff08;ESD静电保护元件&#xff09; 1.1 LC0502N 介绍 应用 ● USB 2.0电源和数据线 ● 机顶盒和数字电视 ● 数字视频接口&#xff08;DVI&#xff09; ● 笔记型电脑 ● SIM端口 ● 10/100以太网 1.2 LC0502N 引脚介绍 &#xff08;无语&#xff0…

1。C语言基础知识回顾

学习嵌入式的C基础知识&#xff0c;主要包括几个核心知识点&#xff1a;三大语法结构、常用的数据类型、函数、结构体、指针、文件操作。 一、顺序结构 程序自上而下依次执行、没有分支、代码简单。 常见顺序结构有&#xff1a;四则运算&#xff1a;&#xff0c;-&#xff0…

通达信顾比倒数线指标公式,信号不漂移

顾比倒数线是由技术派大师戴若顾比发明的&#xff0c;该指标利用三个重要的价格来判断入场或离场时机&#xff0c;可用于盘后制定下一个交易日的操作计划。此外&#xff0c;顾比倒数线还可以用于补充验证其他指标。 在编写顾比倒数线选股公式之前&#xff0c;需要先了解顾比倒…

vue3之vite创建h5项目之2 (sass公共样式、声明组件、路由配置和layout组件 )

目录 vue3之vite创建h5项目之2 &#xff08; &#xff09;1&#xff1a;安装sass1-1 使用sass引入公共样式11-1-1 main.ts 引入公共样式方式 1-2 vite.config.ts 引入公共样式方式21-3样式文件1-3-1 src / style / index.scss ( 适配iphonex等还有引入其他公共的样式 )1-3-2 sr…

CRM部署Always on 后 CRM报无法更新数据库,数据库只读,且读写分离不正常

CRM部署Always on 后 CRM报无法更新数据库&#xff0c;数据库只读&#xff0c;读写分离不正常 问题描述背景信息问题原因解决方案 问题描述 CRM部署Always on 后 CRM报无法更新数据库&#xff0c;数据库只读 读写分离不正常,出现错乱链接。 背景信息 1.2个节点配置SQL serve…

从安全气囊到标配EDR,TOP10控制器供应商领跑市场

2022年1月1日开始&#xff0c;国内新生产新乘用车都必须标配EDR&#xff08;Event Data Recorder&#xff09;&#xff0c;也就是俗称的汽车“黑匣子”&#xff0c;也称为汽车事件数据记录系统&#xff0c;记录的数据可重现事故过程&#xff0c;用于汽车事故分析。 在此之前&am…

【常用算法】进制转换

目录 1. 二进制数、八进制数、十六进制数转换为十进制数 2. 十进制数转换为二进制数、八进制数、十六进制数 3. 二进制数和十六进制数的相互转换 4. 使用电脑计算器进行进制转换 1. 二进制数、八进制数、十六进制数转换为十进制数 十进制数的每一位都是10的指数幂。如&…

基于趋动云的 Stable Diffusion Webui 环境搭建

Stable Diffusion Webui 环境搭建&#xff0c;首先新建一个项目&#xff1a; 然后&#xff0c;选择镜像。注意点公开的&#xff0c;已近做好的这个镜像&#xff0c;superx创建&#xff0c;集成了miniconda3的镜像。 然后选择添加数据源&#xff0c;一样&#xff0c;还是点公开&…

Epinio:Kubernetes 的应用程序开发引擎

王海龙&#xff0c;Rancher 中国社区技术经理&#xff0c;Linux Foundation APAC Evangelist&#xff0c;负责 Rancher 中国技术社区的维护和运营。拥有 9 年的云计算领域经验&#xff0c;经历了 OpenStack 到 Kubernetes 的技术变革&#xff0c;无论底层操作系统 Linux&#x…

A100单机多卡大模型训练踩坑记录(CUDA环境、多GPU卡住且显存100%)

踩坑1&#xff1a;服务器只装了 CUDA Driver 没装 CUDA Toolkit 系统&#xff1a;Ubuntu-18.04 用 deepspeed 跑百亿模型训练时&#xff0c;报关于 CUDA_HOME 的错误。 AssertionError: CUDA_HOME does not exist, unable to compile CUDA op(s)执行 echo $CUDA_HOME 和 nvcc…

HTB-Nineveh

HTB-Nineveh 信息收集80端口443端口80端口-新443端口-新 立足www-data -> amroisamrois -> root其他有意思的地方knock knock - Whos there?socket type 信息收集 80端口 目录扫描 /info.php目录 443端口 目录扫描 这完全没头绪&#xff0c;估计是信息收集漏了东西…

NCR被攻击后服务中断!原是BlackCat勒索软件作祟

近日&#xff0c;在遭到BlackCat勒索软件攻击后&#xff0c;NCR 的 Aloha 销售点平台出现中断。 NCR公司是全球关系管理技术解决方案领导供应商&#xff0c;为全球零售、金融、传讯、制造、旅游、交通及保安等客户提供服务。凭著累积多年的业界知识、专业顾问经验、专业增值应用…

手把手教你本地CPU环境部署清华大模型ChatGLM-6B,利用量化模型,本地即可开始智能聊天,达到ChatGPT的80%

大家好&#xff0c;我是微学AI&#xff0c;今天教你们本地CPU环境部署清华大ChatGLM-6B模型&#xff0c;利用量化模型&#xff0c;每个人都能跑动大模型。ChatGLM-6B是一款出色的中英双语对话模型&#xff0c;拥有超过62亿个参数&#xff0c;可高效地处理日常对话场景。与GLM-1…

数据备份系列:Rsync 备份详解(一)

一、Rsync 简介 1.1 Rsync 是一个远程增量文件备份软件工具 1.2 Rsync 的特性 支持拷贝特殊文件&#xff0c;如连接文件、设备等。可以有排除指定文件或目录同步的功能&#xff0c;相当于打包命令 tar 的排除功能。可以做到保持原文件或目录的权限、时间、软硬链接、属主、组…

MySQL中的锁有哪些,作用是什么?

概述&#xff1a; 锁最要是用来实现MySQL的隔离性。我们都知道事务有四大特性分别是&#xff1a;原子性、一致性、隔离性、持久性&#xff0c;即所说的ACID。 一、什么是ACID 1、原子性&#xff1a;事务中包含有很多操作&#xff0c;这些操作要么全部执行&#xff0c;要么全…