P r o b l e m \mathrm{Problem} Problem
A城市有一个巨大的圆形广场,为了绿化环境和净化空气,市政府决定沿圆形广场外圈种一圈树。
园林部门得到指令后,初步规划出n个种树的位置,顺时针编号1到n。并且每个位置都有一个美观度Ai,如果在这里种树就可以得到这Ai的美观度。但由于A城市土壤肥力欠佳,两棵树决不能种在相邻的位置(i号位置和i+1号位置叫相邻位置。值得注意的是1号和n号也算相邻位置!)。
最终市政府给园林部门提供了m棵树苗并要求全部种上,请你帮忙设计种树方案使得美观度总和最大。如果无法将m棵树苗全部种上,给出无解信息。
S o l u t i o n \mathrm{Solution} Solution
首先证明一个结论:最大的节点两边的点要么同时选要么同时不选。
- 如果选择了最大节点,那么同时不选。
- 如果没有选择最大的节点,假设选择了一边:
接下来考虑贪心:
- 对于当前情况考虑,肯定是要选择最大的节点。
- 但是选择这个最大的节点不一定是最优的怎么办?我们考虑新增一个节点权值为: v l + v r − v x v_l+v_r-v_x vl+