欢迎来到起遇信息学
起遇信息学正处于上线筹建阶段,以下功能已全部开放免费体验: ✅ 完整题库浏览与代码提交评测(C / C++ / Python / Java 等) ✅ 入门到进阶的系列课程试读、作业与考试 ✅ AI 提示、AI 作业分析等智能助教功能 ✅ 赛事模拟与个人能力报告 ✅ 邮箱注册开放 ⏳ 付费课程订阅与微信/支付宝支付通道 ⏳ 手机号登录,微信扫码登录、微信公众号绑定 使用中如遇任何问题,欢迎通过页面底部 **"联系我们"** 与我们沟通。
CF1189B.Number Circle
Number Circle
题目描述
给定 个数 ,你能否将它们排成一个环,使得每个数都严格小于它相邻两个数之和?
例如,对于数组 ,左图的排列是合法的,而右图的排列不合法,因为 且 。

输入格式
第一行包含一个整数 (),表示数字的个数。
第二行包含 个整数 (),表示这些数。给定的数不一定各不相同(即允许有重复)。
输出格式
如果无解,第一行输出 "NO"。
如果有解,第一行输出 "YES"。第二行输出 个数,表示数组在环中的排列顺序。你输出的第一个和最后一个元素在环中视为相邻。如果有多种方案,输出任意一种即可。你可以从任意一个元素开始输出环。
说明/提示
第一组样例中一种可能的排列如下:
;
;
。
第二组样例中也有一种可能的排列。
在第三组样例中,无论如何排列 , 的相邻数都是 和 ,但 。
第四组样例无解。
由 ChatGPT 4.1 翻译
样例
3
2 4 3
YES
4 2 3
5
1 2 3 4 4
YES
4 4 2 1 3
3
13 8 5
NO
4
1 10 100 1000
NO
在线编程 IDE
建议全屏模式获得最佳体验
键盘快捷键
| 进入全屏编程 | Alt+E |
| 递交评测 | Ctrl+Enter |
| 注释/取消注释 | Ctrl+/ |
| 缩放字体 | Ctrl+滚轮 |
第 1 行,第 1 列
0 字符
-
最近自测结果
暂未运行
最近递交结果
暂无递交记录