P2012-拯救世界2【EGF】

正题

题目链接:https://www.luogu.com.cn/problem/P2012


题目大意

121212种东西排列成长度为nnn的序列,要求前四种出现奇数次,后四种出现偶数次,求方案。TTT组数据,对10910^9109取模。

1≤n<263,1≤T≤2×1051\leq n< 2^{63},1\leq T\leq 2\times 10^51n<263,1T2×105


解题思路

显然是EGFEGFEGF,没有限制的话就是exe^xex,奇数就是ex−e−x2\frac{e^x-e^{-x}}{2}2exex,偶数就是ex+e−x2\frac{e^{x}+e^{-x}}{2}2ex+ex,这些都是老生常谈了。

然后答案就是
n!×(ex−e−x2)4(ex+e−x2)4(ex)4n!\times (\frac{e^x-e^{-x}}{2})^4(\frac{e^x+e^{-x}}{2})^4(e^{x})^4n!×(2exex)4(2ex+ex)4(ex)4

然后解出来就是
F(x)=n!×1256×(e12x−4e8x+6e4x−4+e−4x)F(x)=n!\times \frac{1}{256}\times(e^{12x}-4e^{8x}+6e^{4x}-4+e^{-4x})F(x)=n!×2561×(e12x4e8x+6e4x4+e4x)
⇒F(x)[n]=1256×(12n−4×8n+6×4n−4+(−4)n)\Rightarrow F(x)[n]=\frac{1}{256}\times(12^n-4\times 8^n+6\times 4^{n}-4+(-4)^n)F(x)[n]=2561×(12n4×8n+6×4n4+(4)n)

然后发现256256256没有逆元,但是因为这些底数都含有256256256的因数222所以
=81×12n−4−8n−2+6×4n−4+(−4)n−4=81\times 12^{n-4}-8^{n-2}+6\times 4^{n}-4+(-4)^{n-4}=81×12n48n2+6×4n4+(4)n4

小的直接处理就好了

然后发现这样还是过不了,那就用扩展欧拉定理模上一个φ(109)=4×108\varphi(10^9)=4\times 10^8φ(109)=4×108然后根号分治预处理一下光速幂就可以过了。

时间复杂度O(20000+T)O(20000+T)O(20000+T)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cctype>
#define ll long long
using namespace std;
const ll b[5]={0,0,0,0,24},T=20000,N=T+10,P=1e9,Phi=4e8;
ll n,pw2[N],pw3[N],Pw2[N],Pw3[N];
ll read(){ll x=0,f=1;char c=getchar();while(!isdigit(c)){if(c=='-')f=-f;c=getchar();}while(isdigit(c))x=(x<<1)+(x<<3)+c-48,c=getchar();return x*f;
}
void print(ll x)
{if(x>9)print(x/10);putchar(x%10+48);return;}
ll G4(ll n)
{n%=Phi;return Pw2[n/T]*Pw2[n/T]%P*pw2[n%T]%P*pw2[n%T]%P;}
ll G8(ll n)
{n%=Phi;return Pw2[n/T]*pw2[n%T]%P*G4(n)%P;}
ll G12(ll n)
{n%=Phi;return Pw3[n/T]*pw3[n%T]%P*G4(n)%P;}
signed main()
{pw2[0]=pw3[0]=Pw2[0]=Pw3[0]=1;for(ll i=1;i<=T;i++)pw2[i]=pw2[i-1]*2ll%P,pw3[i]=pw3[i-1]*3ll%P;for(ll i=1;i<T;i++)Pw2[i]=Pw2[i-1]*pw2[T]%P,Pw3[i]=Pw3[i-1]*pw3[T]%P;while(1){n=read();if(!n)break;if(n<=4){print(b[n]),putchar('\n');continue;}ll ans=81ll*G12(n-4);ans=ans-G8(n-2);ans=ans+6ll*G4(n-4);ans=ans+((n&1)?-1:1)*G4(n-4);print((ans%P+P)%P);putchar('\n'); }return 0;
}

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

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

相关文章

彼之蜜糖,吾之砒霜——聊聊软件开发中的最佳实践

“描述一个事物&#xff0c;唯有一个名词定义它的概念&#xff0c;唯有一个动词揭露它的行为&#xff0c;唯有一个形容词表现它的特征。要做的&#xff0c;就是用心去寻找那个名词、那个动词、那个形容词……”—— 福楼拜 (Gustave Flaubert)我想讲个故事。很久很久以前&#…

贪心: Array Splitting(数列分段)(洛谷CF1175D)

解析 这题可以转化一下&#xff1a; &#xff08;《神笔马良》。。。。&#xff09; 计算这些长方形对应下标的总加和 我们可以一层一层往上垒,假设第i层起始点为xi&#xff0c;总和为sumi&#xff0c;再设从1到i的前缀和为si 显然第一层x11&#xff0c;sum1sn 对于第二层x2&…

牛客题霸 [合并有序链表] C++题解/答案

牛客题霸 [合并有序链表] C题解/答案 题目描述 将两个有序的链表合并为一个新链表&#xff0c;要求新的链表是通过拼接两个链表的节点来生成的。 题解&#xff1a; 首先判断l1和l2是否为空 然后依次比较l1和l2的值&#xff0c;然后存到新的链表里&#xff0c;当有一方全部结…

2021牛客暑期多校训练营2 G.League of Legends(转化+单调队列)

G.League of Legends Zechariah_2001题解 对于可以包含其他区间的大区间&#xff0c;要使得答案最优无非就是两种分组方式&#xff1a;单独一组或者与被包含的区间一组。单独一组那么贡献就是区间长度&#xff1b;如果说与被包含的区间一组&#xff0c;对答案贡献为0&#xff…

P5056-[模板]插头dp

正题 题目链接:https://www.luogu.com.cn/problem/P5056 题目大意 n∗mn*mn∗m的网格&#xff0c;求有多少条回路可以铺满整个棋盘。 解题思路 插头dpdpdp的&#xff0c;写法是按照题解上的写法。 状态用的是括号匹配&#xff0c;然后用了哈希邻接表&#xff08;挂表&#x…

牛客题霸 [用两个栈实现队列] C++题解/答案

题目描述 用两个栈来实现一个队列&#xff0c;完成队列的Push和Pop操作。 队列中的元素为int类型。 题解&#xff1a; 我们都知道栈的性质是先进后出&#xff0c;队列是先进先出 我们用两个栈来模拟出队列 可以先用一个栈来存数&#xff0c;当要输出时&#xff0c;最上面的是…

Docker最全教程——从理论到实战(一)

容器是应用走向云端之后必然的发展趋势&#xff0c;因此笔者非常乐于和大家分享我们这段时间对容器的理解、心得和实践。本篇教程持续编写了2个星期左右&#xff0c;只是为了大家更好地了解、理解和消化这个技术&#xff0c;能够搭上这波车。你可以关注我们的公众号“magiccode…

二分:路标设置(洛谷)

传送门. 解析 只需二分枚举空旷指数即可 对于单次判断的check函数&#xff0c;可以相当于n个路标把路面分成n1个间隔&#xff0c;而对于每个间隔[l,r]和空旷指数x&#xff08;边界已有路标&#xff09;&#xff0c;所需路标应为&#xff1a; (r-l-1)/x&#xff08;比如[2,5…

2020 ICPC亚洲区域赛(沈阳)F-Kobolds and Catacombs(思维+模拟)

F-Kobolds and Catacombs 考虑每一段&#xff0c;先找到最小的&#xff0c;然后把编号小于它的都化为一组&#xff0c;此时有一个最大值需要把小于最大值的在划分进来&#xff0c;然后又有编号小于它的&#xff0c;于是再把编号小于它的划分为一组&#xff0c;while1 循环一下…

P3190-[HNOI2007]神奇游乐园【插头dp】

正题 题目链接:https://www.luogu.com.cn/problem/P3190 题目大意 n∗mn*mn∗m的网格上有权值&#xff0c;求一条权值和最大的不交回路。 1≤n≤100,1≤m≤61\leq n\leq 100,1\leq m\leq 61≤n≤100,1≤m≤6 解题思路 经典的棋盘形插头dpdpdp&#xff0c;和模板不同的地方是求…

牛客题霸 [最长公共子串]C++题解/答案

牛客题霸 [最长公共子串]C题解/答案 题目描述 给定两个字符串str1和str2,输出两个字符串的最长公共子串&#xff0c;如果最长公共子串为空&#xff0c;输出-1 题解&#xff1a; lcs模板 代码&#xff1a; class Solution { public:/*** longest common substring* param …

二分:[BJWC2008]秦腾与教学评估

洛谷传送门 解析 因为至多有一个单数 假设其位置为k&#xff0c;1-i的累加和为s[i] 则s[1]-s[k-1]全是偶数 s[k]-s[max]全是奇数 答案呈单调性&#xff0c;可以用二分算法 check函数&#xff08;计算前缀和&#xff09;也很容易用O&#xff08;n&#xff09;写出&#xff1a…

微软Azure予力Green Dot客服成就不凡

点击蓝字关注我碧点公司&#xff08;Green Dot&#xff09;是仔细聆听消费者心声&#xff0c;以消费者为导向的金融科技创新公司&#xff0c;致力于为大众带来高效、便捷与体验舒适的个人银行业务。Green Dot创造了预付借记卡产业&#xff0c;也是美国最大的可增值预付借记卡和…

2020 ICPC亚洲区域赛(沈阳)H-The Boomsday Project(双指针+dp)

H-The Boomsday Project Code1 暴力我为人人区间转移 O{N∑qlog⁡N}O\{N\sum q\log N \}O{N∑qlogN} #include<bits/stdc.h> using namespace std; using lllong long; template <class Tint> T rd() {T res0;T fg1;char chgetchar();while(!isdigit(ch)) {if(c…

倍增:st表(模板)(洛谷P3865)

[传送门](https://www.luogu.com.cn/problem/P38 解析 板子题最棒了 用mx[i][j]存储以i为起点&#xff0c;长度为2^j次方的区间内的max 分成前后两段&#xff0c;则可以得到递推式&#xff1a; mx[i][k]max(mx[i][k-1],mx[imi[k-1]][k-1]);而关于初始化&#xff0c;显然&…

首届大湾区 DevOps/微服务秋季分享会圆满落幕!

在科技迅速发展的时代&#xff0c;传统行业积极开展数字化转型以在激烈竞争中脱颖而出&#xff0c;新兴行业不停歇地验证业务模式以找准市场定位&#xff1b;软件与行业变得密不可分&#xff0c;各行各业如何快速响应软件需求&#xff0c;已经成为直接关系到企业核心利益的关键…

牛客题霸 [ 大数加法]C++题解/答案

牛客题霸 [ 大数加法]C题解/答案 题解&#xff1a; 本质就是模拟加法运算 想要让s与t长度统一&#xff0c;不足的部分用0来补充 然后从最后一位开始&#xff0c;两个数相加&#xff0c;同时如果超过10&#xff0c;就把多的部分加到下一位 其实就是我们小学在草稿纸上运算加法…

codeforces1012 B. Chemical table(并查集+思维)

B. Chemical table One of the way to solve this problem is to interprete the cells in 2d matrix as an edge in the bipartite graph, that is a cell (i, j) is an edge between i of the left part and j of the right part. 将行号放一边&#xff0c;列号放一边构造…

P7099-[yLOI2020]灼【数学期望,结论】

正题 题目链接:https://www.luogu.com.cn/problem/P7099 题目大意 给出nnn个坐标轴上的点&#xff0c;qqq次询问从某点出发每次等概率向左或者向右一格求到达某个给出点的期望步数。 保证每个询问点左右都有目标点 1≤n≤105,1≤q≤5106,1≤xi,yi≤1091\leq n\leq 10^5,1\leq…

P4258-[WC2016]挑战NPC【带花树】

正题 题目链接:https://www.luogu.com.cn/problem/P4258 题目大意 给出nnn个球&#xff0c;mmm个篮筐&#xff0c;每个球都可以被放入一些特定的篮筐&#xff0c;每个球都要放&#xff0c;要求球的个数小于等于111的篮筐数量最多。 保证有解&#xff0c;输出方案。 1≤T≤5,1…