[杂题训练]CF1228E Another Filling the Grid(容斥),CF936C Lock Puzzle(构造)

文章目录

  • T1:CF1228E Another Filling the Grid
    • solution
    • code
  • T2:CF936C Lock Puzzle
    • solution
    • code

T1:CF1228E Another Filling the Grid

点我

solution

反过来思考,用所有方案数➖不合法方案数
很容易想到的是——容斥!!
首先只考虑行数
减去至少一行没有111的方案数,加上至少两行没有111的方案数…
得出以下柿子
∑i=0n(−1)i×Cni×(k−1)i×n×kn2−i×n\sum_{i=0}^n(-1)^i\times C_n^i\times (k-1)^{i\times n}\times k^{n^2-i\times n}i=0n(1)i×Cni×(k1)i×n×kn2i×n
(枚举iii行不含111,那么这iii行共i×ni\times ni×n个格子,除了111不能填,只有k−1k-1k1个数可以填,剩下的n2−i×nn^2-i\times nn2i×n格子kkk个数都可以填)
再加上列的限制
∑i=0n∑j=0n(−1)i+j×Cni×Cnj×(k−1)i×n+j×n−i×j×kn2−(i×n+j×n−i×j)\sum_{i=0}^n\sum_{j=0}^n(-1)^{i+j}\times C_n^i\times C_n^j\times (k-1)^{i\times n+j\times n-i\times j}\times k^{n^2-(i\times n+j\times n-i\times j)}i=0nj=0n(1)i+j×Cni×Cnj×(k1)i×n+j×ni×j×kn2(i×n+j×ni×j)
iii行与jjj列包含的格子数=i\ =\ i = i行包含的格子数i×n+ji\times n\ +\ ji×n + j列包含的格子数−i,j\ -\ i,j  i,j共同包含的格子数i×ji\times ji×j


到这里,O(n2)O(n^2)O(n2)已经可以悠闲地过这道题了,但是我们要 没事找事吃饱了撑的 热爱学习,深度挖掘,万一nnn一下子猛加到1e5,1e61e5,1e61e5,1e6级别呢??
换言之,我们是否还能再找到一个O(nlogn)O(nlogn)O(nlogn)的优秀算法呢??

答案当然是ofcourse,whynotof\ course,why\ notof course,why not


来化一下上面的优美柿子

(k−1)i×n+j×n−i×j×kn2−(i×n+j×n−i×j)(k-1)^{i\times n+j\times n-i\times j}\times k^{n^2-(i\times n+j\times n-i\times j)}(k1)i×n+j×ni×j×kn2(i×n+j×ni×j)
=(k−1)i×(n−j)×(k−1)j×n×k(n−i)(n−j)=(k-1)^{i\times (n-j)}\times (k-1)^{j\times n}\times k^{(n-i)(n-j)}=(k1)i×(nj)×(k1)j×n×k(ni)(nj)
=[(k−1)i](n−j)×[(k−1)n]j×(kn−i)n−j=[(k-1)^i]^{(n-j)}\times [(k-1)^n]^j\times (k^{n-i})^{n-j}=[(k1)i](nj)×[(k1)n]j×(kni)nj
=[(k−1)i×kn−i]n−j×[(k−1)n]j=[(k-1)^i\times k^{n-i}]^{n-j}\times [(k-1)^n]^j=[(k1)i×kni]nj×[(k1)n]j
到这里就非常明显了,让我们换个硬元更加明显
x=(k−1)i×kn−i,y=(k−1)nx=(k-1)^i\times k^{n-i},y=(k-1)^nx=(k1)i×kni,y=(k1)n
则上述柿子可变为xn−j×yjx^{n-j}\times y^jxnj×yj
太像我们的二项式小可爱了,但是不要 不穿裤子就不跑 ,还少了点什么,我们需要把前面的
(−1)j×Cnj(-1)^j\times C_n^j(1)j×Cnj提过来才行
(−1)j×Cnj×xn−j×yj=(x−y)n(-1)^j\times C_n^j\times x^{n-j}\times y^j=(x-y)^n(1)j×Cnj×xnj×yj=(xy)n
于是答案柿子就可以剔除jjj,只剩下与iii有关的柿子了
∑i=0n(−1)i×Cni×[(k−1)i×kn−i+(k−1)n]n\sum_{i=0}^n(-1)^i\times C_n^i\times [(k-1)^i\times k^{n-i}+(k-1)^n]^ni=0n(1)i×Cni×[(k1)i×kni+(k1)n]n
次方就找快速幂qkpowqkpowqkpow老火鸡完成,时间复杂度就成功降为O(nlong)O(nlong)O(nlong)
当然kkk的幂次可以提前预处理,这样可以少跑几次快速幂,优化可能有 个芝麻大点

code

#include <cstdio>
#define int long long
#define mod 1000000007
#define maxn 300
int n, k;
int fac[maxn], inv[maxn];int qkpow( int x, int y ) {int ans = 1;while( y ) {if( y & 1 ) ans = ans * x % mod;x = x * x % mod;y >>= 1;}return ans;
}int C( int n, int m ) {if( n < m ) return 0;return fac[n] * inv[m] % mod * inv[n - m] % mod;
}signed main() {scanf( "%lld %lld", &n, &k );fac[0] = inv[0] = 1;for( int i = 1;i <= n;i ++ )fac[i] = fac[i - 1] * i % mod;inv[n] = qkpow( fac[n], mod - 2 );for( int i = n - 1;i;i -- ) inv[i] = inv[i + 1] * ( i + 1 ) % mod;int ans = 0;for( int i = 0;i <= n;i ++ ) {if( i & 1 )ans = ( ans - C( n, i ) * qkpow( ( qkpow( k - 1, i ) * qkpow( k, n - i ) % mod - qkpow( k - 1, n ) + mod ) % mod, n ) % mod + mod ) % mod;elseans = ( ans + C( n, i ) * qkpow( ( qkpow( k - 1, i ) * qkpow( k, n - i ) % mod - qkpow( k - 1, n ) + mod ) % mod, n ) % mod ) % mod;}	printf( "%lld", ans );return 0;
}

T2:CF936C Lock Puzzle

戳一戳

solution

一般这种限制多少次以内就算成功的题目肯定是个构造题!!
观察数据范围n≤2000n\le 2000n2000,操作次数≤6100\le 61006100
大胆猜想应该让我们用3×n3\times n3×n的操作左右完成构造
即对于每一个字符最多只用333步就让ta锁定在我们想要ta在的位置


直接说正解吧
假设现在的sss串长下列样子

AxBCA\ x\ B\ CA x B C

A,B,CA,B,CA,B,C均为一个字符子串,CCC稍特殊一点,既是sss串的后缀,同时要为ttt串的前缀,且最长
当然三个串可以为空
xxx为我们想移动的字符

现在目标是将xxx移动到CCC后面一个,即CxCxCx构成一个新的ttt的前缀


操作①:shiftlen(BC)shift\ len(BC)shift len(BC)
原串变为 C′B′AxC'\ B'\ A\ xC B A x

操作②:shiftlen(1)shift\ len(1)shift len(1)
继续变为 xC′B′Ax\ C'\ B'\ Ax C B A

操作③:shiftlen(n−1)shift\ len(n-1)shift len(n1)
成为 A′BCxA'\ B\ C\ xA B C x

我们只关心CxCxCx是否一起出现在最后面,前面的AAA是否颠倒,不在乎滴

code

#include <cstdio>
#include <iostream>
#include <algorithm>
using namespace std;
#define maxn 2005
int n, tot;
char s[maxn], t[maxn];
int tot_s[maxn], tot_t[maxn], ans[maxn << 2];int main() {scanf( "%d %s %s", &n, s + 1, t + 1 );for( int i = 1;i <= n;i ++ )tot_s[s[i]] ++, tot_t[t[i]] ++;for( int i = 'a';i <= 'z';i ++ )if( tot_s[i] != tot_t[i] ) return ! printf( "-1\n" );int cnt = 0;for( int i = 1;i <= n;i ++ )if( s[i] == t[1] ) {bool flag = 1;for( int j = i;j <= n;j ++ )if( s[j] != t[j - i + 1] ) {flag = 0;break;}if( flag ) {cnt = n - i + 1;break;}}while( 1 ) {bool flag = 1;for( int i = 1;i <= n;i ++ )if( s[i] != t[i] ) {flag = 0;break;}if( flag ) break;int pos;for( int i = 1;i <= n - cnt;i ++ )if( s[i] == t[cnt + 1] ) {pos = i;break;}ans[++ tot] = n - pos;ans[++ tot] = 1;ans[++ tot] = n - 1;if( pos > 1 ) reverse( s + 1, s + pos );char temp = s[pos];for( int i = pos;i < n;i ++ )s[i] = s[i + 1]; s[n] = temp;cnt ++;}printf( "%d\n", tot );for( int i = 1;i <= tot;i ++ )printf( "%d ", ans[i] );return 0;
}

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

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

相关文章

Asp.Net Core 轻松学-经常使用异步的你,可能需要看看这个文章

前言事情的起因是由于一段简单的数据库连接代码引起&#xff0c;这段代码从语法上看&#xff0c;是没有任何问题&#xff1b;但是就是莫名其妙的报错了&#xff0c;这段代码极其简单&#xff0c;就是打开数据库连接&#xff0c;读取一条记录&#xff0c;然后立即更新到数据库中…

CF1146F: Leaf Partition(树形dp)

解析 阴间dp题qwq 不难设计dp&#xff1a; dpx,0:x节点没有被包含、子树内的方案数dp_{x,0}:x节点没有被包含、子树内的方案数dpx,0​:x节点没有被包含、子树内的方案数 dpx,1:x节点被包含、子树内的方案数dp_{x,1}:x节点被包含、子树内的方案数dpx,1​:x节点被包含、子树内的…

Take Your Seat Gym - 102222D

Take Your Seat Gym - 102222D 题意&#xff1a; 第一次是n个人坐飞机&#xff0c;按照1到n的顺序登机&#xff0c;第一个人登机牌丢了&#xff0c;他随机做一个座位&#xff0c;2到n个人上来按照自己的登机牌坐座位&#xff0c;如果他的座位被坐了&#xff0c;就在随机找一个…

CF446D-DZY Loves Games【高斯消元,矩阵乘法】

正题 题目链接:https://www.luogu.com.cn/problem/CF446D 题目大意 给出nnn个点mmm条边的一张无向图&#xff0c;一些点有陷阱&#xff0c;走到时会损失一条生命&#xff0c;总共有kkk条生命&#xff0c;求从111出发随机游走到nnn没有死亡且到终点时仅剩一条命的概率。 1≤n≤…

「BJOI2019」奥术神杖(AC自动机+DP)

文章目录titlesolutioncodetitle solution 令MagicViVjVk...MagicV_i\times V_j\times V_k...MagicVi​Vj​Vk​... 这里对Magicc\sqrt[c]{Magic}cMagic​有一个很巧妙的转换——取对数 Magicc(Magic)1celoge(Magic)1c\sqrt[c]{Magic}(Magic)^{\frac{1}{c}}e^{log_e(Magic)^{…

try.dot.net 的正确使用姿势

来源&#xff1a;https://www.cnblogs.com/7tiny/p/10277600.html【简介】微软官方前不久发布了 try.dot.net 这个有趣的网址&#xff0c;开始只是图个新鲜看了一下&#xff0c;后面通过自身实践过后&#xff0c;发现这着实算是个“有趣”的站点&#xff01;首先我们大概地列举…

A - TOYS POJ - 2318

A - TOYS POJ - 2318 题意&#xff1a; 一个盒子中有n个隔板&#xff0c;分出n1个空间&#xff08;从左往右空间的编号分别是0…n&#xff09;&#xff0c;&#xff08;隔板之间不会相交&#xff0c;且按照从左往右的顺序给出&#xff09;&#xff0c;现在给你m个坐标的物品&…

CF1016F:Road Projects(树形dp)

解析 好题 意思就是我没做出来 稍微分析一下就可以发现加边的位置始终是一样的 换句话说询问完全可以O1 关键就是找到这条边加在哪里 一开始我完全把这道题看成了彻头彻尾的数据结构题 容易想到二分答案 然后上个树状树组搞一搞就行了 但是遇到一个关键的问题 它无法解决加边…

CF750E-New Year and Old Subsequence【动态dp】

正题 题目链接:https://www.luogu.com.cn/problem/CF750E 题目大意 给出一个长度为nnn的数字字符串&#xff0c;qqq次询问给出其的一个子串ttt&#xff0c;询问至少要删除多少个数字才能使得其中包含201720172017这个子序列却不包含201620162016这个子序列。 1≤n,q≤21051\l…

[BJOI2017]魔法咒语(AC自动机+DP+矩阵快速幂)

文章目录titlesolutioncodetitle solution 针对数据编程才是坠吊的&#xff01;&#xff01;&#xff01; 观察数据&#xff0c;发现分隔数据的LLL跨度过大&#xff0c;没有衔接——推测很有可能是分数据做法 ①&#xff1a;考虑L≤100L\le100L≤100的情况 可以暴力DPDPDP转移…

P6242-[模板]线段树3【吉司机线段树】

正题 题目链接:https://www.luogu.com.cn/problem/P6242 题目大意 给出一个长度为nnn的序列aaa&#xff0c;mmm次要求支持操作 区间加上一个值kkk区间所有aia_iai​变为min{ai,k}min\{a_i,k\}min{ai​,k}区间求和区间求最大值区间求历史最大值 1≤n,q≤51051\leq n,q\leq 5\…

洛谷P1912:诗人小G(二分栈、决策单调性)

二分栈&#xff0c;就是通过二分维护的栈 &#xff08;逃&#xff09; 解析 本题的决策单调性可以说是显然 但是本题是同维度&#xff08;其实只有一维&#xff09;自左向右转移&#xff0c;分治的写法是不能奏效的 所以我们使用决策点调性的另一种实现方法&#xff1a;二分栈…

[国家集训队]middle(二分+主席树[中位数思维题])

文章目录点击查看solutioncode点击查看 solution 简单口胡一下就跑 考虑二分答案ansansans 区间[x1,x2],x1∈[a,b]&#xff0c;x2∈[c,d][x1,x2],x1∈[a,b]&#xff0c;x2∈[c,d][x1,x2],x1∈[a,b]&#xff0c;x2∈[c,d] 大于等于ansansans的设为111&#xff0c;小于ansans…

使用Roslyn脚本化C#代码,C#动态脚本实现方案

来源&#xff1a;https://www.cnblogs.com/7tiny/p/10279349.html【前言】Roslyn 是微软公司开源的 .NET 编译器。编译器支持 C# 和 Visual Basic 代码编译&#xff0c;并提供丰富的代码分析 API。Roslyn不仅仅可以直接编译输出&#xff0c;难能可贵的就是上述描述中的开放了编…

Moving On Gym - 102222F

Moving On Gym - 102222F 题意&#xff1a; 有 n 个城市&#xff0c;q 次询问. 给出每个城市的危险度 r 和 城市的邻接矩阵. 每次询问给出 u、v、w&#xff0c;求从 u 到 v 且不经过其他危险度超过 w 的城市的最短路. 题解&#xff1a; floyd 变形 我队友一开始想的是每次…

10.27模拟 总结

前言 220pts 100200100 按照gg的建议从《暴力模式》转化为《切题模式》 但是感觉本次有点难阿… 进入石头门困境… 再四道题中反复横跳 说实话心态是炸的 T1&#xff08;伪&#xff09;正解出来后才安了一些心 由于这次数据的强度确实不高 T1和T4的做法其实都很假 过掉也有运气…

[构造训练]CF1227G Not Same,CF1375H Set Merging,CF1364E X-OR

文章目录T1&#xff1a;CF1227G Not SamesolutioncodeT2&#xff1a;CF1364E X-ORsolutioncodeT3&#xff1a;CF1375H Set Mergingsolutioncode~~脑子是个好东西&#xff0c;希望人人都有构造真的不是个东西&#xff0c;看了一天视频&#xff0c;没有一道题会做~~ T1&#xff…

asp.net core 环境(Development、Staging 、Production)

一.在asp.net core中使用多个环境ASP.NET Core 配置是基于运行时环境, 使用环境变量。ASP.NET Core 在应用启动时读取环境变量ASPNETCORE_ENVIRONMENT&#xff0c;并将该值存储在 IHostingEnvironment.EnvironmentName 中。ASPNETCORE_ENVIRONMENT 可设置为任意值&#xff0c;但…

AT3913-XOR Tree【状压dp】

正题 题目链接:https://www.luogu.com.cn/problem/AT3913 题目大意 给出一棵有边权的树&#xff0c;你每次可以选择一条链让所有的边异或上同一个值&#xff0c;求最少的操作次数使得所有边的权值都为000。 2≤n≤105,0≤w<162\leq n\leq 10^5,0\leq w<162≤n≤105,0≤…

2018宁夏邀请赛

2018宁夏邀请赛 A Maximum Element In A Stack B Gym 102222B Rolling The Polygon C Gym 102222C Caesar Cipher D Gym 102222D Take Your Seat E Gym 102222E 2-3-4 Tree F Gym 102222F Moving On G Gym 102222G Factories H Gym 102222H Fight Against Monsters I Gym 10222…