「考试」 Or
不得不说是一道多项式神题了。
虽然说颓代码颓的很厉害不过最终A掉了。
好好讲一讲这道题。
涉及的知识点是:高阶导数,NTT,指数型母函数,泰勒公式,以及意志力和数学推导能力。
那就开始了。
一个测试点一个测试点来。
首先注意到$b[i]=lim_{i=1}^{i<=n}(|=a[i])$
1.$n,k<=4$ 直接爆搜。$O(2^{nk})$
2.$n,k<=10$考虑状压dp。
设$dp[i][s]$为$a$的$i$项前缀或和。
那么有转移$dp[i+1][s|t]+=dp[i][s]*[(s|t)!=s]$
这样是$O(n4^{k})$
3.$n,k<=300$。
首先优化状压dp,我们其实并不关心状压dp中状态的1是那些1,我们只关心有几个1。
那么得到$dp[i][j]$前$i$位的$a$或和中有$j$个1,且清楚是哪些1的方案数。
$dp[i][j]=\sum\limits_{k=0}^{j-1}dp[i-1][k]2^kC_{K-k}^{j-k}$
复杂度是$O(nk^2)$
4.59分
优化上述$dp$
其实可以看到卷积的影子吧。
设$g[i][j]$前$i$位的$a$或和中有$j$个1,不清楚是那些1的方案数。
$g[i][j]=\sum\limits_{k=0}^{j-1}g[i-1][k]2^kC_j^{j-k}$
那么$dp[i][j]=C_K^jg[i][j]$
可以看出来g是一个卷积的形式了。
那么复杂度$O(nklogk)$
5.AC
优化上述dp。
改变g的枚举方式。
$g[i][j]=\sum\limits_{k=1}^{j}g[i-1][j-k]2^{j-k}C_{j}^{k}$
展开组合数。
$g[i][j]=\sum\limits_{k=1}^{j}g[i-1][j-k]2^{j-k}\frac{j!}{k!(j-k)!}$
那么也就是说
$\frac{g[i][j]}{j!}=\frac{\sum\limits_{k=1}^{j-1}g[i-1][j-k]2^{j-k}}{(j-k)!}\frac{1}{k!}$
可以看出指数型母函数的样子了。
生成函数$G(x)=\sum\limits_{k=1}^{j-1}\frac{g[i][j]}{j!}$
引入泰勒公式。
$+\infty$为正无穷。
对于任何一个函数$f$
$f(x)=\sum\limits_{i=0}^{+\infty}\frac{f^{(i)}(x_0)(x-x_0)^i}{i!}$
证明:
对$f^{(m)}(x_0)(x-x_0)^m$求$m$阶导。
首先$x^n$的导数为$nx^{n-1}$
那么
1.$mf^{(m)}(x_0)(x-x_0)^{m-1}$
2.$m(m-1)f^{(m)}(x_0)(x-x_0)^{m-2}$
......
m.$m!f^{(m)}(x_0)$
在往后都是0了,$m!f(x_0)$是常数。
那么其实$f^{(m)}(x_0)=m!f(x_0)$因为其他项带$(x-x_0)$,所以都是0。
除掉$m!$
$f(x)=\sum\limits_{i=0}^{+\infty}\frac{f^{(i)}(x_0)(x-x_0)^i}{i!}$
得到泰勒公式的结论了。
证毕。
第二个引理$e^x=\sum\limits_{i=0}^{+\infty}\frac{x^i}{i!}$
证明:
首先$e^x$的导数仍然是$e^x$
$e^x=\sum\limits_{i=0}^{+\infty}\frac{f^{(i)}(x_0)(x-x_0)^i}{i!}$
设$\frac{f^{(i)}(x_0)}{i!}=a_i$
$e^x=\sum\limits_{i=0}^{+\infty}\frac{a_i(x-x_0)^i}{i!}$
两侧取导。
$e^x=0+\sum\limits_{i=1}^{+\infty}ia_{i-1}(x-x_0)^{i-1}$
$a_0=a_1$
$a_1=2a_2$
$a_2=3a_3$
...
$a_{n-1}=na_n$
那么解得$a_i=\frac{a_0}{i!}$
回代。
$e^x=a_0\sum\limits_{i=0}^{+\infty}\frac{x^i}{i!}$
当$x=0$时
$e^x=1=a_0\sum\limits_{i=0}^{+\infty}\frac{x^i}{i!}$
$a_0=1$
$e^x=\sum\limits_{i=0}^{+\infty}\frac{x^i}{i!}$
证毕。
推推式子得到了$G_i(x)=G_{i-1}(2x)*(e^x-1)$是卷积。
用$(G(x))[x^i]$代表多项式$G(x)$在$x^i$处的系数。
代入$\frac{g[i][j]}{j!}=\frac{\sum\limits_{k=1}^{j}g[i-1][j-k]2^{j-k}}{(j-k)!}\frac{1}{k!}$
那么也就等价于。
$(G_i(x))[x^j]=\sum\limits_{k=1}^{j}(G_{i-1}(x))[x^{j-k}]2^{j-k}((e^x)[x^k])$
解释一下。
$G(2x)$在$[x^k]$的系数是$\frac{g[i-1][k]}{k!}2^k$
$e^x$在$[x^k]$的系数是$\frac{1}{k!}$
好那么有这个式子了。
继续。
$G_0(x)=1$
回代得到。
$G_n(x)=\prod\limits_{i=0}^{n-1}(e^{2^ix}-1)$
这个形式可以用类似快速幂的方式优化。
快速幂我不知道怎么想出来的只知道是对的。
那么也就是说可以在$O(nlog^2n)$时间内解决。
常数巨大。
「考试」 Or的更多相关文章
- 「考试」CSP-S 2020
乱扯 爆炸的过程是这样的 写了\(2.5h\)的\(T1\)过不去大样例,自闭了 决定调\(T2\)然后过了样例但事实上写的完全是假的 这个时候突然\(T1\)灵光一闪就没再看\(T2\)了 然后就一 ...
- 「考试」noip模拟9,11,13
9.1 辣鸡 可以把答案分成 每个矩形内部连线 和 矩形之间的连线 两部分 前半部分即为\(2(w-1)(h-1)\),后半部分可以模拟求(就是讨论四种相邻的情况) 如果\(n^2\)选择暴力模拟是有 ...
- 「考试」$5T$
啊因为最近题实在是好啊,只能四五篇四五篇写了. T1. 括号序列的确简单. 当我们维护左右$cnt$后. 到一个左括号的地方的话. 答案就是:$$\sum\limits_{i=1}^{min(lc,r ...
- 「考试」小P的生成树
考场上想到一半正解,没想到随机化,不然也许能够$A$掉. 题目所说的其实就是向量加法,求模长最长的向量生成树. 我们考虑对于两个向量,必然在平行边形对角线方向上,他们的投影和是最大的,长度就是对角线长 ...
- 「考试」num (破800纪念)
是第800题啦. 怎么说,$rvalue$学长写的已经挺好的了,我在这里做一点补充,写一点理解. 但是这道题真的值得写一下题解,毕竟一百行也算是数论工程题了. 定义函数 $Fp(k,n)$为$n$中$ ...
- 「考试」weight
正解是树剖. 首先Kru求最小生成树. 然后分别考虑树边和非树边的答案. 首先是非树边,非树边链接的两个点在MST上能够构成一条链. 这条链上最大的那条边-1就是这条边的答案. 为什么. 模拟Kru的 ...
- 「考试」联赛模拟36-39,noip晚间小测2-3
36.1 party(CF623D) 很是鸡贼的一道题 首先要明确一点,抓人是有策略,而不是随机的,可以认为等同于按一个给定的顺序猜人,那么这时猜中的概率就只是抓住这个人的概率了 对于每一次猜测,因为 ...
- 「CSP-S」2019年第一届Day1游记+题解
「CSP-S」2019年第一届Day1游记+题解 Day 1 7:30 A.M. 8:10 A.M. 8:30 A.M. T1 格雷码 题目 考场经历+思考(正解) 8:50 A.M. T2 括号树 ...
- 「CSP」第一届提高组考后总结
「CSP」第一届提高组考后总结 问题分析+反思 成绩 心态 考前心态 考时心态 考后心态 方法 心灵鸡汤... 在学习了三年之后,我们信竞迎来了初中最后一次大考,也是第一次 CSPCSPCSP 考试. ...
随机推荐
- 小程序webview跳转页面后没有返回按钮完美解决方案
随着小程序越来越火爆,使一个产品如果只有公众号H5页面和APP显得不怎么完美,总感觉不搭上小程序这趟流量车,就会少了点什么,心里别扭地很.在此驱动下,我所在公司也决定赶紧上车. 但是,如果要按照小程序 ...
- 使用Newspaper3k框架快速抓取文章信息
一.框架介绍 Newspaper是一个python3库,但是Newspaper框架并不适用于实际工程类新闻信息爬取工作,框架不稳定,爬取过程中会有各种bug,例如获取不到url.新闻信息等,但对于想获 ...
- uniapp 与C# 加解密
1 uni-app操作 (1) 打开HBuilderX的视图->显示终端 cd 切换到你项目的根目录 执行命令 npm install crypto-js 安装成功后你的项目根目录会生成node ...
- CentOS 7 单机安装Redis Cluster(3主3从)
首先,本篇要基于单实例的安装,你的机器上已经有一个Redishttps://gper.club/articles/7e7e7f7ff7g5egc4g6b 为了节省机器,我们直接把6个Redis实例安装 ...
- Redis未授权访问写Webshell和公私钥认证获取root权限
0x01 什么是Redis未授权访问漏洞 Redis 默认情况下,会绑定在 0.0.0.0:,如果没有进行采用相关的策略,比如添加防火墙规则避免其他非信任来源 ip 访问等,这样将会将 Redis 服 ...
- PHP compact
1.函数的作用:将变量转成数组 2.函数的参数: @params string $varname1 @params string $varname2 ... @params array $varnam ...
- Cocos2d-x 学习笔记(9) Action 运行原理
1. 从一个Action开始 1.1 创建 在Scene里写一个Sprite,并添加Action: Sprite *sp = Sprite::create("m1.png"); M ...
- freertos学习
freertos的基本框架如下 注意有三点很重要: 1.任务的资源 (1)任务优先级:freertos 能够调度的任务优先级在freertosConfig.h中的configMAX_PRIORITIE ...
- ElasticSearch Bulk API
做一个简单的记录,以便自己后续查找 一.环境要求 ElasticSearch 7.3.0 Kibana 7.3.0 二.详情 ElasticSearch 的 Bulk API 可以批量进行索引或者删除 ...
- xml 文件操作
'XML添加 Public Sub Add(ID As String, RFSerialnumber As String, Mood As Integer) If reatch(RFS ...