洛谷1220题解:动态规划与区间DP优化解法

贾蔷
• 阅读 6

洛谷1220题解:动态规划与区间DP优化解法

一、题目解读

洛谷1220题要求计算在n个位置放置灯的情况下,通过关闭连续区间灯并移动至区间端点,使得总耗电量最小。需考虑灯的功率与位置差异,设计高效的算法求解最优策略。

二、解题思路

  1. 动态规划 + 区间DP:定义状态dp[i][j][0/1]表示关闭i-j区间灯后,最后位于左端(i)或右端(j)的最小耗电量。

  2. 前缀和优化:使用sum数组存储灯功率前缀和,简化区间电量计算。

  3. 状态转移核心:

○ 向左扩展:从i+1到i,计算移动至左端的耗电量(考虑剩余区间电量与移动距离)。

○ 向右扩展:从j-1到j,同理计算右端移动耗电。

  1. 边界初始化:初始状态为单灯区间dp[c][c][0/1]=0,逐步扩展至全局最优解。

三、解题步骤

  1. 输入与预处理:读取n、c及灯位置/功率,计算前缀和sum[]。

  2. 初始化dp数组:全部设为无穷大,避免非法状态干扰。

  3. 枚举区间长度:从2到n遍历,确保覆盖所有连续区间。

  4. 状态转移循环:

○ 计算左扩展成本:dp[i][j][0] = min(从i+1扩展左移成本, 从i+1扩展右移后左移成本)。

○ 计算右扩展成本:dp[i][j][1] = min(从j-1扩展右移成本, 从j-1扩展左移后右移成本)。

  1. 输出结果:比较最终区间[1,n]的左右端点耗电最小值。

四、代码与注释

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;

const int MAXN = 55;
int n, c;
int pos[MAXN], power[MAXN];
int sum[MAXN]; // 前缀和数组
int dp[MAXN][MAXN][2]; // dp[i][j][0/1]表示关闭i-j区间的灯,最后位于左/右端的最小耗电量

int main() {
    cin >> n >> c;
    for(int i = 1; i <= n; ++i) {
        cin >> pos[i] >> power[i];
        sum[i] = sum[i-1] + power[i]; // 计算前缀和
    }

    memset(dp, 0x3f, sizeof(dp)); // 初始化无穷大
    dp[c][c][0] = dp[c][c][1] = 0; // 起点状态

    for(int len = 2; len <= n; ++len) { // 枚举区间长度
        for(int i = 1; i + len - 1 <= n; ++i) { // 枚举左端点
            int j = i + len - 1; // 右端点

            // 情况1:从i+1走到i(向左扩展)
            int cost_left = (sum[n] - sum[j] + sum[i]) * (pos[i+1] - pos[i]);
            dp[i][j][0] = min(dp[i+1][j][0] + cost_left, 
                             dp[i+1][j][1] + (sum[n] - sum[j] + sum[i]) * (pos[j] - pos[i]));

            // 情况2:从j-1走到j(向右扩展) 
            int cost_right = (sum[n] - sum[j-1] + sum[i-1]) * (pos[j] - pos[j-1]);
            dp[i][j][1] = min(dp[i][j-1][1] + cost_right,
                             dp[i][j-1][0] + (sum[n] - sum[j-1] + sum[i-1]) * (pos[j] - pos[i]));
        }
    }

    cout << min(dp[1][n][0], dp[1][n][1]) << endl;
    return 0;
}

五、总结

洛谷1220通过区间DP与动态规划的结合,将复杂的多决策问题转化为可递推状态转移方程。前缀和的应用显著降低了计算复杂度,而分情况讨论移动方向(左/右)的耗电优化,是解题的核心技巧。此解法不仅适用于本题,也为类似区间优化问题提供了通用思路。

来源:信奥自学之路

点赞
收藏
评论区
推荐文章
Stella981 Stella981
3年前
A Mini Locomotive(动态规划 01)
 /\ 题意:选出3个连续的数的个数 为K的区间,使他们的和最大分析: dp\j\\i\max(dp\jk\\i1\value\j\,dp\j1\\i\);dp\j\\i\:从j个数种选出i个连续区间 数值的最大和value\j\:第j个区间内的数的和和背包有点像,但要活用\
贾蔷 贾蔷
2星期前
牛客12576题全解析:动态规划+质因数分解解决跳跃问题
一、题目解读牛客12576题是一道经典的算法题,要求给定起点N和终点M,求解从N到M的最少跳跃次数。题目考察的核心在于路径优化与动态规划思想,需结合数论中的质因数分解技巧,通过合理设计算法降低时间复杂度,避免暴力枚举的指数级耗时。二、解题思路采用“动态规划
贾蔷 贾蔷
2星期前
动态规划实战:洛谷P1220关路灯问题最优解(附C++代码 AC100)
一、问题重述题目描述:在一条笔直的道路上安装了N盏路灯,每盏灯有位置和功率。老张从某起点出发,每秒移动1单位距离,经过的灯可以关闭(节省电量)。要求计算关闭所有灯的最小耗电量。二、算法解析1.问题建模这是一个典型的区间DP问题,需要考虑:位置信息处理耗电量
深度学习 深度学习
2星期前
CSP-J 2024扑克牌问题:贪心算法的经典应用
题目重述与分析给定n张扑克牌,每张牌有分值ai。玩家轮流取牌,每次可从两端取一张,最终获得取牌分值和。双方均采取最优策略,求先手能获得的最大分数差。核心考点:区间DP与博弈论结合最优子结构性质记忆化搜索实现算法设计思路状态定义:dp
深度学习 深度学习
2星期前
2024蓝桥杯省赛B组前缀总分(洛谷P12124)解题思路与代码详解
一、题目解读2024年蓝桥杯省B组题目“前缀总分”(对应洛谷P12124)要求计算给定字符串集合中,所有前缀的最长公共前缀(LCP)的总分,并找出通过移动字符位置后可能获得的最大总分。题目考察字符串处理与动态规划能力,需高效计算LCP并优化得分策略。二、解
贾蔷 贾蔷
2星期前
2023年GESP六级题解:洛谷P10108闯关游戏动态规划解法详解
一、题目解读本文针对2023年GESP六级题目“闯关游戏”(洛谷P10108)进行详细解析。题目要求玩家通过不同关卡路径选择,计算从起点到终点的最大得分。关卡间存在跳跃规则,需结合动态规划思想设计高效算法,最终输出最优得分。二、解题思路采用动态规划(Dyn
深度学习 深度学习
2星期前
洛谷P2034题解:动态规划+单调队列优化求解最大K段子段和问题
一、题目解读洛谷P2034题目要求给定一个长度为n的整数数组,将其分成不超过k段,求各段和的最大值。该问题属于经典动态规划问题的扩展,需结合优化技巧高效求解。二、解题思路采用动态规划单调队列优化的策略。核心思想是定义状态dp
贾蔷 贾蔷
1星期前
动态规划预处理+滑动窗口:力扣2420题"好下标"解法详解
一、问题理解题目要求找出中满足特定条件的"好下标":对于下标i,其左侧k个元素必须是非递增的,右侧k个元素必须是非递减的。这是典型的数组区间性质检查问题。二、解题思路1.预处理核心思想是通过两次预处理:left数组:记录每个位置向左的非长度right数组:
深度学习 深度学习
5天前
洛谷P2190题解:铁路售票系统车厢计算(差分数组+前缀和优化)
一、题目解读P2190题要求解决铁路售票系统中的车厢数量计算问题。题目给定n个车站和m条订票申请,每条申请包含区间实现区间修改的。通过差分记录每个站点的乘客变化(如进入/离开人数),再计算前缀和得到各站点的实时乘客数,从而找出最大值。特别处理环形区间(即
深度学习 深度学习
1天前
NOIP 2008火柴棒等式题解(C++代码实现) 动态规划与枚举算法详解
一、题目解读问题(,)要求使用给定数量的火柴棒,构造形如ABC的等式,其中A、B、C均为整数,且火柴棒总数恰好等于输入值。需统计符合条件的等式数量。题目核心在于将数字拆解与火柴棒消耗建模为数学问题,寻找高效解法。二、解题思路采用火柴棒计数策略:1.关系