2023.8.27 闲话
给两个正整数 ,随机生成长度为 的处于 内的元素不重的序列 .
怎么做呢?哦哦首先拒绝采样我们是非常会的,每次不断随机直到和以前都不同,这样不难证明是均匀随机 . 那么算一下复杂度吧,期望是概率的倒数,那么每次选一下成功的概率就是 ,所以期望次数就是 .
令 ,那么复杂度可以改成 ,选 次就是 .
这个算法的问题在于如果 非常小的话()这个就成 这种量级了,还是不太能接受的 .
考虑对于 比较小的情况有没有什么好做法,注意到最朴素的想法就是给整个值域 shuffle 出来暴力取前 个,这样就是 的了,那么想一下怎么平衡 .
直接解 可以得到的是 ,那么以 为阈值分治即可,最后可以得到的是复杂度为 ,非常优秀啊 .
以下是博客签名,正文无关
本文来自博客园,作者:yspm,转载请注明原文链接:https://www.cnblogs.com/CDOI-24374/p/17652862.html
版权声明:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议(CC BY-NC-SA 4.0)进行许可。看完如果觉得有用请点个赞吧 QwQ
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】