文章目录

  • 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=0∑n​(−1)i×Cni​×(k−1)i×n×kn2−i×n
(枚举iii行不含111,那么这iii行共i×ni\times ni×n个格子,除了111不能填,只有k−1k-1k−1个数可以填,剩下的n2−i×nn^2-i\times nn2−i×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=0∑n​j=0∑n​(−1)i+j×Cni​×Cnj​×(k−1)i×n+j×n−i×j×kn2−(i×n+j×n−i×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)}(k−1)i×n+j×n−i×j×kn2−(i×n+j×n−i×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)}=(k−1)i×(n−j)×(k−1)j×n×k(n−i)(n−j)
=[(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}=[(k−1)i](n−j)×[(k−1)n]j×(kn−i)n−j
=[(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=[(k−1)i×kn−i]n−j×[(k−1)n]j
到这里就非常明显了,让我们换个硬元更加明显
令x=(k−1)i×kn−i,y=(k−1)nx=(k-1)^i\times k^{n-i},y=(k-1)^nx=(k−1)i×kn−i,y=(k−1)n
则上述柿子可变为xn−j×yjx^{n-j}\times y^jxn−j×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​×xn−j×yj=(x−y)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=0∑n​(−1)i×Cni​×[(k−1)i×kn−i+(k−1)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 2000n≤2000,操作次数≤6100\le 6100≤6100
大胆猜想应该让我们用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(n−1)
成为 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;
}

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

  1. CF杂题训练(交互题不做,2500以上的看情况吧)

    CF专练 CF1562 A The Miracle and the Sleeper B Scenes From a Memory C Rings D Two Hundred Twenty One E ...

  2. 吉首大学新星杯L题 小李子的老年生活【容斥好题(只是问题比较裸)】

    传送门 // 题意就是给定一个n, 求1 - n 中与n互质的数的平方和. // 思路: 问题我们可以进行转换, 就是我们得到1 - n的所有数的平方和, 然后我们要做的就是减去n的素数因子(不是素数 ...

  3. AtCoder 杂题训练

    前言: 因为要普及了,今年没一等就可以退役去学文化课了,所以暑假把历年noip普及组都刷了一遍,离noip还有50+天,想弄点强化训练什么的. 想了想,就这些天学文化课之余有空就把AtCoder之前那 ...

  4. 2019.03.29 NOIP训练 友好国度(点分治+容斥)

    传送门 思路: 直接上点分治+容斥计算每个因数对应的贡献即可. 代码: #include<bits/stdc++.h> #define ri register int using name ...

  5. 20190509杂题选讲

    这次杂题选讲好多思维题神仙题啊= =顺便学了波线段树上二分= = Normal 题目大意戳这 CF1083C CDW讲的神仙题*1 题解戳这 AGC002E 我讲的题,是个人写的程序都比我写的程序跑得 ...

  6. AcWing蓝桥杯AB组辅导课10、疑难杂题

    文章目录 前言 例题1:AcWing 1242. 修改数组(并查集) 分析 题解:单链表式并查集 例题2:AcWing 1234. 倍数问题(背包问题+贪心) 分析 题解1:01背包问题,三维解法(贪 ...

  7. ACM图论+数据结构杂题总结

    ACM:图论+数据结构杂题总结 T1: 题目描述:(出处:Atcoder Regular Contest 067 Yakiniku Restaurants) 一条街上有N家烧烤餐馆.餐厅从西到东编号为 ...

  8. PTA寒假基础题训练(含解题思路)(下)

    目录 7-36 字符串的冒泡排序 AC代码: 7-37 龟兔赛跑 AC代码: 7-38 N个数求和 AC代码: 7-39 数列求和-加强版 AC代码: 7-40 抓老鼠啊~亏了还是赚了? AC代码: ...

  9. PTA寒假基础题训练(含解题思路)(中)

    目录 7-19 两个有序单链表求差集 AC代码: 7-20 统计数字字符和空格 AC代码: 7-21 打印沙漏 AC代码: 7-22 Wifi密码 AC代码: 7-23 福到了 AC代码: 7-24 ...

最新文章

  1. iOS 解决app退出后台应用重新启动的问题
  2. 遥望星空FTP文件同步工具(附源码)1.0 发布
  3. 玩转spring boot——结合阿里云持续交付
  4. Navicat和DBeaver的查询快捷键
  5. 自主定义适合自己的Keil主题
  6. Stanford Machine Learning
  7. 数据结构-----二叉树,树,森林之间的转换
  8. MyBatis的association示例
  9. python封装 继承 多态 举例_python面向对象中的封装、继承、多态
  10. java excel 导入 加校验_POI实现excel各种验证和导入的思路总结
  11. 61. Rotate List
  12. deepin安装卡在deepin标志界面解决方案
  13. Python 文本转语音
  14. 劲爆!群晖docker视频
  15. A problem occurred starting process 'command 'xxx
  16. 好用的软件及网站收录
  17. 软件开发工程师工作总结(转)
  18. python 字符串转字典的几种方法
  19. GauGAN (SPADE) 水记 (seg2img)
  20. Python程序设计(第三版)约翰·策勒 编程练习课后答案(第二章)

热门文章

  1. 仿真模拟,需要注意这几点!
  2. mysql普通标转分区表_MySQL分区表到普通表互转
  3. 红旗河最早设计计算机的目的,论红旗河的利弊及其替代方案
  4. python3读取文件夹-python3获取文件及文件夹大小
  5. phppage类封装分页功能_php显示页码分页类的封装
  6. 面试避坑手册之 Java字节流和字符流总结IO流!
  7. python面向对象继承_四. python面向对象(继承)
  8. typora公式zuo对齐_Markdown编辑神器-Typora
  9. Linux链接文件包括,Linux操作系统——系统各目录有什么作用、以及文件链接过程...
  10. [蓝桥杯][2013年第四届真题]剪格子-dfs