洛谷 B4135 [信息与未来 2014] 取数 题解

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 2n105,1xi109

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 i1 个元素,就需要考虑前 i − 3 i-3 i3 个元素的情况。此时选取的元素和为 d p [ i − 3 ] + a [ i − 1 ] + a [ i ] dp[i-3]+a[i-1]+a[i] dp[i3]+a[i1]+a[i]。其中,dp[i-3] 是考虑前 i-3 个元素的最大和,a[i-1]a[i] 是当前选择的两个部相邻元素。

    • 情况二不选第 i i i 个元素:若不选第 i i i 个元素,那么最大元素和就同等于考虑前 i − 1 i-1 i1 个元素时的最大元素和,即 dp[i-1]。因为不选第 i i i 个元素,所以问题规模就缩小到了前 i − 1 i-1 i1 个元素

  • 因此,状态转移方程为 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[i1],dp[i3]+a[i1]+a[i]);


3. 代码片段分析

由于此题只需要输入就可以直接套状态转移方程,就不给予分析了(一前面讲的是够详细了,二是我只能讲成这样了)。


4. AC 代码

如上所述,没必要出示代码,但如果你是这种情况,我只能引用一句 OI 界的名言:

十年 OI 一场空,不开 long \hspace{1mm} long 见祖宗。


有任何问题请指出,如果对你有帮助,点个赞再走吧!谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

—海燕—

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值