B4135 [信息与未来 2014] 取数 题解
免责声明:如遇雷同,纯属巧合
完整题目
B4135 [信息与未来 2014] 取数
题目描述
有 n n n 个数排成一排,从 n n n 个数中任取若干个数,取数规则为每次取相邻的 2 2 2 个数,不能取 1 1 1 个,也不能取多于 2 2 2 个连续的数,找一种取法,使取到数的和为最大。
输入格式
第一行一个整数,表示 n n n;
第二行有 n n n 个整数,表示 x 1 , x 2 , ⋯ , x n x_1,x_2,\cdots,x_n x1,x2,⋯,xn。输出格式
一个整数,即合理取法中最大的和。
输入输出样例 #1
输入 #1
6 13 2 17 14 8 16输出 #1
43说明/提示
2 ≤ n ≤ 1 0 5 , 1 ≤ x i ≤ 1 0 9 2\le n\le 10^5,1\le x_i\le 10^9 2≤n≤105,1≤xi≤109。
1. 读题
-
题意:在一个序列中任取若干个数,取数规则为每次取相邻的 2 个数,且不能取多于 2 个连续的数,使和最大。
-
样例解释(我一开始就没弄明白): 13 2 17 14 8 16 13 \hspace{1mm}2\hspace{1mm}17 \hspace{1mm}14\hspace{1mm}8\hspace{1mm}16 1321714816 每次取相邻的 2 个数,且不能取多于 2 个连续的数,使和最大。
-
第一次: 13 2 [ 17 14 ] 8 16 和为 0 + 17 + 14 = 31 13 \hspace{1mm}2\hspace{1mm}\left [ 17 \hspace{1mm}14\right ]\hspace{1mm}8\hspace{1mm}16\hspace{3mm}和为0+17+14=31 132[1714]816和为0+17+14=31。
-
第二次: 13 2 17 14 [ 8 16 ] 和为 31 + 8 + 16 = 43 13 \hspace{1mm}2\hspace{1mm}17 \hspace{1mm}14\hspace{1mm}\left [ 8\hspace{1mm}16\right ]\hspace{3mm}和为31+8+16=43 1321714[816]和为31+8+16=43。
-
2. 使用动态规划解决
-
动态转移方程推导
-
情况一选择第 i i i 个元素:若选择第 i i i 个元素,就不能选取第 i − 1 i-1 i−1 个元素,就需要考虑前 i − 3 i-3 i−3 个元素的情况。此时选取的元素和为 d p [ i − 3 ] + a [ i − 1 ] + a [ i ] dp[i-3]+a[i-1]+a[i] dp[i−3]+a[i−1]+a[i]。其中,
dp[i-3]是考虑前 i-3 个元素的最大和,a[i-1]和a[i]是当前选择的两个部相邻元素。 -
情况二不选第 i i i 个元素:若不选第 i i i 个元素,那么最大元素和就同等于考虑前 i − 1 i-1 i−1 个元素时的最大元素和,即
dp[i-1]。因为不选第 i i i 个元素,所以问题规模就缩小到了前 i − 1 i-1 i−1 个元素
-
-
因此,状态转移方程为 d p [ i ] = m a x ( d p [ i − 1 ] , d p [ i − 3 ] + a [ i − 1 ] + a [ i ] ) ; dp[i]=max(dp[i-1],dp[i-3]+a[i-1]+a[i]); dp[i]=max(dp[i−1],dp[i−3]+a[i−1]+a[i]);。
3. 代码片段分析
由于此题只需要输入就可以直接套状态转移方程,就不给予分析了(一前面讲的是够详细了,二是我只能讲成这样了)。
4. AC 代码
如上所述,没必要出示代码,但如果你是这种情况,我只能引用一句 OI 界的名言:
十年 OI 一场空,不开 long \hspace{1mm} long 见祖宗。
有任何问题请指出,如果对你有帮助,点个赞再走吧!谢谢!
882

被折叠的 条评论
为什么被折叠?



