容斥法解决错排问题

错排问题

简单来说,错排问题就是问有多少个长度为的排列,使得对于所有的都有

递推式

错排的一个递推式就是

这个递推式复杂度显然是线性的。

关于这个递推式的推导请自行百度。这里不再赘述。

容斥法解错排问题

第一次看到错排问题的时候,并没有推导出上面的递推式。而是用了一种容斥的方法。自认为更加简单易懂吧。

既然是每个数字都不能放在对应的位置。那么按照容斥的一般套路,我们强制有个数字放在了对应位置。其他数字不管他。显然这个数字有种方案。其他数字有种排列方式。

所以式子就很显然了:

复杂度同样也是线性的。

其实可以发现,用容斥继续推下去的话,依然可以推出上面的递推式。所以这两种解法本质上是等价的。

全部评论

相关推荐

是每个人事都这样与找工作的人这样沟通吗?正常询问不可以吗
超时空记忆丶:这种人适合跟我聊 我能骂得她心里难受一天,这种byd一看就是欠骂,这么好的机会楼主别错过。
点赞 评论 收藏
分享
湫湫湫不会java:为啥25届才17,个人信息没打码哦
点赞 评论 收藏
分享
Southyeung:我说一下我的看法(有冒犯实属抱歉):(1)简历不太美观,给我一种看都不想看的感觉,感觉字体还是排版问题;(2)numpy就一个基础包,机器学习算法是什么鬼?我感觉你把svm那些写上去都要好一点。(2)课程不要写,没人看,换成获奖经历;(3)项目太少了,至少2-3个,是在不行把网上学习的也写上去。
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务