hihoCoder#1743:K-偏差排列(矩阵快速幂+状压dp)
题意
如果一个 的排列 中的任意元素 都满足 ,我们就称 是 -偏差排列。
给定 和 ,请你计算一共有少个不同的排列是 -偏差排列。
例如对于 ,有 个 -偏差排列:。
由于答案可能非常大,你只需要输出答案模 的余数。
对于 的数据,
对于 的数据,
题解
一道好题~
这是它的最初版本 #1732 : 1-偏差排列 .
那个找规律就是 斐波那契数列 了, dp 的话也是一样的结果 .
对于这个题我们可以沿用那题思路, 考虑一个位置 能放哪些数, 根据定义能放 中共 个数.
考虑状压到 这个点, 这些数中的哪些被放了, 每次转移的时候考虑放入一个数, 这个数之前不能出现, 这样就是合法转移了.
最后到 的时候, 不能放比 大的数, 且小于等于 的数都要放进去, 只会有那个位置存在正确答案, 这个状态 (也就是意味着 都得选) .
当 的时候要特判掉一些诡异的特殊情况 .
然后这样直接写就有 了.
有一些不合法状态不能转移, 也就是要放的数不存在于 之间.
这样的话, 就是矩阵快速幂套路优化了, 考虑对这个转移系数建立矩阵, 然后它的 次幂中的 这个位置就会存在最后的答案咯...
代码
__EOF__

本文作者:zjp_shadow
本文链接:https://www.cnblogs.com/zjp-shadow/p/9042753.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/zjp-shadow/p/9042753.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】