【学军NOIP开放题2-D】均分(构造)(分类讨论)
均分
题目链接:学军NOIP开放题2-D
题目大意
要你给 n 个数赋值,然后使得每个数满足它标识数对应的条件。
标识数是 0 则剩下的 n-1 个数不能分成和相同的两堆,是 1 就是可以。
然后判断无解,或者给出构造方案。
思路
我们考虑根据这个大致思路来构造,就是尽可能的让不可以分成的和是奇数。
然后开始分类讨论:(下面让 为标识符为 的个数)
首先判掉两个特殊的,就是只有 或 。
只有 就如果 是偶数就全都是 ,如果是奇数你可以 个 ,然后一个 一个 。
只有 就如果 是奇数就全是 ,否则就无解。
无解这里可以证一下,首先如果所有数的 我们可以同除效果不变。
那因为你要全部有解,那一定至少总和一定要都是偶数,所以所有数奇偶性相同。
如果都是偶数就可以同除 ,那如果是奇数那总和就一定是奇数(奇数*奇数=奇数),所以就无解了。
然后再判掉两个:
的话如果 就无解,否则我们可以这样构造:
的那个放 ,然后 中放一个 ,其它都放 。
的时候 的位置放 , 的放 个 ,一个 。
然后再按 的奇偶分类讨论。
如果 是奇数,那就好办了,直接 的填 , 的填 。
如果 是偶数,我们就看 。
如果 是偶数,那也好办 的填 , 的填 。
如果 是奇数,我们可以这样: 里面一个 ,一个 ,剩下的都是 ,然后 里面都是所有 填的数的和。
这些自己证明一下都可以证出来。
然后就可以了。
代码
__EOF__

本文作者:あおいSakura
本文链接:https://www.cnblogs.com/Sakura-TJH/p/XJOI_3412_1.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/Sakura-TJH/p/XJOI_3412_1.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现