區間dp

题目描述

某一村庄在一条路线上安装了n盏路灯,每盏灯的功率有大有小(即同一段时间内消耗的电量有多有少)。老张就住在这条路中间某一路灯旁,他有一项工作就是每天早上天亮时一盏一盏地关掉这些路灯。

为了给村里节省电费,老张记录下了每盏路灯的位置和功率,他每次关灯时也都是尽快地去关,但是老张不知道怎样去关灯才能够最节省电。他每天都是在天亮时首先关掉自己所处位置的路灯,然后可以向左也可以向右去关灯。开始他以为先算一下左边路灯的总功率再算一下右边路灯的总功率,然后选择先关掉功率大的一边,再回过头来关掉另一边的路灯,而事实并非如此,因为在关的过程中适当地调头有可能会更省一些。

现在已知老张走的速度为1m/s,每个路灯的位置(是一个整数,即距路线起点的距离,单位:m)、功率(W),老张关灯所用的时间很短而可以忽略不计。

请你为老张编一程序来安排关灯的顺序,使从老张开始关灯时刻算起所有灯消耗电最少(灯关掉后便不再消耗电了)。

输入输出格式

输入格式:

文件第一行是两个数字n(1<=n<=50,表示路灯的总数)和c(1<=c<=n老张所处位置的路灯号);

接下来n行,每行两个数据,表示第1盏到第n盏路灯的位置和功率。数据保证路灯位置单调递增。

输出格式:

一个数据,即最少的功耗(单位:J,1J=1W·s)。

输入输出样例

输入样例#1:

5 3
2 10
3 20
5 20
6 30
8 10
输出样例#1:

270  

说明

输出解释:

{此时关灯顺序为3 4 2 1 5,不必输出这个关灯顺序}


看題解仍然看不懂,結果在dalao解釋后才看懂轉移方程:

用 f [ i ] [ j ] [ 0/1 ]表示從 i 號路燈到 j 號路燈,人在區間 左/右 端點時的最小花費。

f [ i ] [ j ] [ 0 ]有兩種轉移方式:從i+1的左端點往左走一個關 i 號路燈,或者從 i+1,j 的右端點走到左端來關 i 路燈。

同理 f [ i ] [ j ] [ 1 ]也就類似的知道了。

用前綴和來計算 i 到 j 區間以外的花費,乘上距離就是這段轉移用的花費。

枚舉區間長度和左端點即可,然而並不知道為什麼不用枚舉斷開的點,可能是因為狀態轉移不需要兩個區間合併吧。

這狀態轉移方程到底是怎麼想出來的啊......代碼:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,c;
struct node{
int w,p;
}t[];
int f[][][];
int sum[];//前綴和
//int cal(int i,int j,int l,int r)//i,j路燈編號,l,r區間左右
//{
// return (t[j].p-t[i].p)*(sum[n]-(sum[r]-sum[l-1]));//除去這個區間
//}
int main()
{
scanf("%d%d",&n,&c);
for(int i=;i<=n;i++){
scanf("%d%d",&t[i].p,&t[i].w);
sum[i]=sum[i-]+t[i].w;
}
//初始化
  memset(f,,sizeof(f));
f[c][c][]=f[c][c][]=;
for(int k=;k<=n;k++)//枚舉區間長度
for(int i=;i<=n-(k-);i++){//枚舉左端點
int j=i+k-;
f[i][j][]=min(f[i+][j][]+(t[i+].p-t[i].p)*(sum[n]-(sum[j]-sum[i])),//從i+1的左端點往左走一個關i路燈
//sum[j]-sum[i]是因為過程中i並沒有被關
f[i+][j][]+(t[j].p-t[i].p)*(sum[n]-(sum[j]-sum[i])));//或者從i+1,j的右端點走到左端來關i路燈
f[i][j][]=min(f[i][j-][]+(t[j].p-t[j-].p)*(sum[n]-(sum[j-]-sum[i-])),//這裡j沒被關而且i還要-1
f[i][j-][]+(t[j].p-t[i].p)*(sum[n]-(sum[j-]-sum[i-])) );
}
printf("%d",min(f[][n][],f[][n][]));
}

還是不太會做區間dp啊

2019-03-08 19:00:02

又出現了一個新問題,這樣枚舉所有區間最後得到的最小答案一定是從 c 出發的嗎?

我認為是這樣的:我們是從小到大枚舉的區間長度和起始位置,每一個小區間都是由更小的區間推出來的,

而最小的區間也就是1長度的區間是由我們手動賦初值的,也就是區間長度為1的時候在c點最優,

這樣就保證了每一個由c點推出來的區間都是最優解這樣就保證了最後1~n的區間也是最優的。

[題解] luogu p1220 關路燈的更多相关文章

  1. [題解]luogu P1156 垃圾陷阱

    前言:[數據刪除] 來源:題解 不發題面了 首先我们来分析题目,“每个垃圾都可以用来吃或堆放”,浓浓的透露出一个背包气息.我们可以类比背包问题的放或不放.于是dp[i][j]dp[i][j]dp[i] ...

  2. [題解](單調隊列dp)【2016noip福建夏令營】探險

    P1917 -- 探险 时间限制:1000MS      内存限制:131072KB 题目描述(explore.cpp) π+e去遗迹探险,遗迹里有 N 个宝箱,有的装满了珠宝,有的装着废品. π+e ...

  3. [題解](最小生成樹/LCA)luogu_P1967貨車運輸

    一道好題不出所料又抄的題解 1.首先對於這張圖肯定要考慮走哪些邊不走哪些邊,發現我們想要的肯定那些邊權最大的邊,所以想到最大生成樹 這樣能保證選到盡量大的邊 2.跑完最大生成樹后每兩點之間就有唯一路徑 ...

  4. [Luogu P1613]跑路 (DP+倍增+最短路)

    题面 传送门:https://www.luogu.org/problemnew/show/P1613 Solution 挺有意思的一道题. 题面已经挺明显的描述出了这题的主要思想:倍增. 先这样想,我 ...

  5. Luogu 1613 跑路(最短路径,倍增)

    Luogu 1613 跑路(最短路径,倍增) Description 小A的工作不仅繁琐,更有苛刻的规定,要求小A每天早上在6:00之前到达公司,否则这个月工资清零.可是小A偏偏又有赖床的坏毛病.于是 ...

  6. [題解](水/數學)luogu_P1147連續自然數和

    尺取法a掉 然而數學解法為 等差數列求和公式: sum(L,R)=(L+R)(R-L+1)/2=M 即(L+R)(R-L+1)=2M 可以把2M分解成两个数之积,假设分成了两个数K1,K2,且K1&l ...

  7. [題解](最小生成樹)luogu_P1265

    首先考虑最小生成树的模型,唯一不同的是第二种情形. 即“三个或三个以上的城市申请修建的公路成环” 考虑该情形,因为修路的申请是申请离它最近的城市,所以上述条件实质上为 “存在三个或三个以上的城市,他们 ...

  8. [題解](二分答案/單調隊列)luogu_P1419尋找段落

    果然又抄的題解... 顯然答案具有單調性,而對于平均數計算的式子我們移一下項, 若s[l..r]>mid*(r-l+1)无解, 於是我們把每個數都減去一個mid,看和的正負即可,如果為正就可能有 ...

  9. [題解]luogu_P1120小木棍(搜索)

    好久以前抄的題解,現在重新抄題解做一下 1.對所有木棍從大到小排序,後用小的比較靈活 2.限制加入的木棍單調遞減,因為先/后用長/短木棍等價,反正就是那兩根 3.預處理出重複木棍的位置,防止重複搜索相 ...

随机推荐

  1. APP上线审核注意事项

    基本要点 ·         不能导致手机故障(比如崩溃或屏幕问题) ·         长时间/过度使用之后反应仍然很快 ·         应用内的所有价格信息中不能用固定值代替可变变量 ·    ...

  2. html5学习笔记(1)-新标签

    最近在做的项目中用到了Html5的部分标签,经师父提醒感觉自己用section的次数多的有点过分,今天去找了一篇HTML5新标签的使用方法,特意贴了上来,感谢原作者的分享,方便以后自己使用~~~ HT ...

  3. BestCoder Round #92 1001 Skip the Class —— 字典树 or map容器

    题目链接:http://bestcoder.hdu.edu.cn/contests/contest_showproblem.php?cid=748&pid=1001 题解: 1.trie树 关 ...

  4. Codeforces Round #254 (Div. 2) A. DZY Loves Chessboard —— dfs

    题目链接: http://codeforces.com/problemset/problem/445/A 题解: 这道题是在现场赛的最后一分钟通过的,相当惊险,而且做的过程也很曲折. 先是用递推,结果 ...

  5. Android BLE 总结-源码篇(BluetoothLeAdvertiser)

    在做Android BLE的应用程序时,我们发出广播数据是调用BluetoothLeAdvertiser的startAdvertising方法,如下所示: mBluetoothLeAdvertiser ...

  6. UITabBar 设置选中、未选中状态下title的字体颜色

    一.如果只是设置选中状态的字体颜色,使用 tintColor  就可以达到效果 self.tabBar.tintColor = [UIColor redColor]; 二.但如果要将未选中状态和选中状 ...

  7. hdu-5754 Life Winner Bo(博弈)

    题目链接: Life Winner Bo Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 131072/131072 K (Java/ ...

  8. web缓存概述

    缓存无处不在,所展示出的仅仅是服务器端的缓存,我们从细节层面一层层分析 但是在此之前,我们先要知道什么是缓存与为什么要使用缓存,是时候百度一波喽~ 缓存就是数据交换的缓冲区(称作Cache),当某一硬 ...

  9. Union All ,Merge,Merge join 区别

    本文转自:http://www.cnblogs.com/gudujianxiao/archive/2012/07/17/2594709.html SSIS Data Flow 中有几个组件可以实现不同 ...

  10. 可移植的配置visual studio工程第三方库

    现在编程有太多的好用的第三方库,例如 计算机视觉方面的opencv c++的扩充库boost 特殊的第三方库,相机库,通讯库等 使用这些库给我们带来了极大的便利,同时也有很多困扰.这个工程在我电脑上明 ...