2016vijos 1-3 兔子的晚会(生成函数+倍增FWT)
发布日期:2025-06-19 14:02:41
浏览次数:4
分类:精选文章
本文共 1683 字,大约阅读时间需要 5 分钟。
求出序列的生成函数后,倍增FWT
在解决某些序列问题时,我们需要求出序列的生成函数,并对其进行倍增快速傅里叶变换(FWT)。以下是实现这一过程的详细方法。
首先,我们在代码中定义了常量和模数:
#define N 2048const int mod=1e9+7;int inv;int f[N+1];
接下来,定义了一个快速幂的函数来计算大数的幂取模:
int Pow(int a,int b){ int res=1; for(;b;a=1LL*a*a%mod,b >>=1) if(b & 1) res = 1LL*res*a % mod; return res;} 然后,实现了FWT变换和逆变换的函数。这些函数用于对序列进行快速傅里叶变换和逆变换:
void FWT(int *a,int n){ int x,y; for(int d=1;d < n;d <<=1){ for(int m=d; m < n; m <<=1){ for(int i=0; i < n; i += m){ for(int j=0; j < d; j++){ x = a[i+j]; y = a[i+j+d]; a[i+j] = (x + y) % mod; a[i+j+d] = (x - y + mod) % mod; a[i+j] -= a[i+j]; a[i+j] %= mod; a[i+j+d] += a[i+j+d] < 0 ? mod : 0; } } } }}void IFWT(int *a,int n){ int x,y; for(int d=1;d < n;d <<=1){ for(int m=d; m < n; m <<=1){ for(int i=0; i < n; i += m){ for(int j=0; j < d; j++){ x = a[i+j]; y = a[i+j+d]; a[i+j] = (1LL*(x + y) * inv % mod); a[i+j+d] = (1LL*(x - y + mod) % mod * inv % mod); } } } }} 最后,在主函数中,我们读取输入并初始化变量:
int main(){ freopen("xor.in","r",stdin); freopen("xor.out","w",stdout); int n,m,l,r; scanf("%d%d%d%d",&n,&m,&l,&r); n = 2*n +1; inv = Pow(2,mod-2); len = 1; ans = 0; while(len <= x + m) len <<=1; for(i=0; i < len; i++) f[i] = Pow(f[i],n); fwt(f,len); ifwt(f,len); ans += f[0]; printf("%d",ans);} 通过以上步骤,我们可以高效地求出序列的生成函数并对其进行倍增FWT变换,解决实际问题。
发表评论
最新留言
网站不错 人气很旺了 加油
[***.192.178.218]2026年06月03日 10时26分17秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
php微信 开发笔记,微信WebApp开发总结笔记
2023-03-01
php微信公众号开发access_token获取
2023-03-01
php微信公众号开发微信认证开发者
2023-03-01
php微信公众号开发用户基本信息
2023-03-01
php怎么将对象变成数组,php怎么将对象转换成数组
2023-03-01
RabbitMQ - 消息堆积问题的最佳解决方案?惰性队列
2023-03-01
php怎样比较两数大小,jquery如何判断两个数值的大小
2023-03-01
PHP性能监控 - 开启xhprof(一)
2023-03-01
PHP性能监控 - 怎么看xhprof报告(二)
2023-03-01
php截取字符串代码,PHP字符串截取_php
2023-03-01
php截取字符串,无乱码
2023-03-01
php手冊,php手冊之變量范圍
2023-03-01
PHP手机号码归属地查询API接口
2023-03-01
PHP执行耗时脚本实时输出内容
2023-03-01
PHP扩展安装
2023-03-01
PHP扩展数据库连接参数说明详解
2023-03-01
php把get参数放入数组_php怎么将数组转为url参数?
2023-03-01
PHP投票小程序
2023-03-01
php拆分数组不改变key值
2023-03-01
php接口返回数据 用echo 还是return?
2023-03-01