[FJOI2016]神秘数

https://www.luogu.com.cn/problem/P4587

好题,想了一晚终于会暴力了。

不妨将序列升序,设当前能表示出来的数的区间为 [0,mx],那么下一个需要表示出来的数是 mx+1,现在就有看能不能通过 ai 表示(扫过去),发现条件即 mx+1ai0,倘若成立,则区间应变为 [0,mx+ai]

那么现在我们就要找到第一个没法表示出来时的位置。

发现条件即 sumi1suml1+1ai0,即 sumi1aisuml11,那么就是区间内有 0/1,找第一个 1 的位置,线段树二分即可。


__EOF__

本文作者F x o r G
本文链接https://www.cnblogs.com/xugangfan/p/16173560.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   FxorG  阅读(30)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示