关路灯
来源:互联网 发布:一家6口服毒身亡 知乎 编辑:程序博客网 时间:2024/04/26 19:22
题目描述 Description
多瑞卡得到了一份有趣而高薪的工作。每天早晨他必须关掉他所在村庄的街灯。所有的街灯都被设置在一条直路的同一侧。
多瑞卡每晚到早晨5点钟都在晚会上,然后他开始关灯。开始时,他站在某一盏路灯的旁边。
每盏灯都有一个给定功率的电灯泡,因为多端卡有着自觉的节能意识,他希望在耗能总数最少的情况下将所有的灯关掉。
多端卡因为太累了,所以只能以1m/s的速度行走。关灯不需要花费额外的时间,因为当他通过时就能将灯关掉。
编写程序,计算在给定路灯设置,灯泡功率以及多端卡的起始位置的情况下关掉所有的灯需耗费的最小能量。
输入描述 Input Description
输入文件的第一行包含一个整数N,2≤N≤1000,表示该村庄路灯的数量。
第二行包含一个整数V,1≤V≤N,表示多瑞卡开始关灯的路灯号码。
接下来的N行中,每行包含两个用空格隔开的整数D和W,用来描述每盏灯的参数,其中0≤D≤1000,0≤W≤1000。D表示该路灯与村庄开始处的距离(用米为单位来表示),W表示灯泡的功率,即在每秒种该灯泡所消耗的能量数。路灯是按顺序给定的。
输出描述 Output Description
输出文件的第一行即唯一的一行应包含一个整数,即消耗能量之和的最小值。注意结果小超过1,000,000,000。
样例输入 Sample Input
4
3
2 2
5 8
6 1
8 7
样例输出 Sample Output
56
#include<iostream>using namespace std;long long dis[1001],w[1001],g[1001][1001];long long f[1001][1001][2];int main(){ long long n,m;cin>>n;cin>>m; for (int i=1;i<=n;++i) { long long x;cin>>dis[i]>>x; w[i]+=w[i-1]+x; } for (int i=1;i<=n;++i) for (int j=i;j<=n;++j) {g[i][j]=w[n]-w[j]+w[i-1]; f[i][j][0]=1e9; f[i][j][1]=1e9; } f[m][m][0]=0; f[m][m][1]=0; for (int i=n;i>=1;--i) for (int j=i+1;j<=n;++j) { f[i][j][0]=min(f[i+1][j][0]+(dis[i+1]-dis[i])*(g[i+1][j]), f[i+1][j][1]+(dis[j]-dis[i])*(g[i+1][j])); f[i][j][1]=min(f[i][j-1][1]+(dis[j]-dis[j-1])*(g[i][j-1]), f[i][j-1][0]+(dis[j]-dis[i])*(g[i][j-1])); } cout<<min(f[1][n][0],f[1][n][1]);}
区间dp,f[i][j][0]表示关i 到 j 最后关 i
f[i][j][1]表示关i 到 i 最后关 j
t表示除i 到 j 外灯的总功率。
注意状态转移方程于状态变换的关系
- 关路灯
- 关路灯
- 1.10关路灯
- wiki 1258 关路灯
- codevs 1258 关路灯
- 洛谷1220 关路灯
- 洛谷1220关路灯
- 洛谷P1220 关路灯
- CODEVS 1258 关路灯
- CODEVS 1258 关路灯
- codevs1258 关路灯
- 洛谷 P1220 关路灯
- 洛谷 P1220 关路灯
- 洛谷 P1220 关路灯
- 洛谷P1220 关路灯
- P1220 关路灯
- 洛谷 P1220 关路灯
- 洛谷 P1220 关路灯
- KindEditor 存文本粘贴
- 利用python读取xml布局文件下面使用中文或者引用资源文件里面的中文,并且显示行号
- CSS3 border-radius实现边框圆角
- sudo apt-get update 出现Reading package lists… Error!
- 修改操作测试用例
- 关路灯
- 不是SELECTed表达式
- 去掉标题栏和全屏显示
- 如何实现线程安全?
- 服务器分布式和集群的区别
- NSUserDefaults应用
- 记一次清除浏览器广告的经历
- VirtualBox network issue - HostInterfaceNetworking-VirtualBox Host-Only Ethernet Adapter
- HDU 1089-1096 A+B for Input-Output Practice(IO系列)