[USACO07NOV]电话线Telephone Wire
[USACO07NOV]电话线Telephone Wire
时间限制: 1 Sec 内存限制: 128 MB
题目描述
输入
Line 1: Two space-separated integers: N and C
- Lines 2..N+1: Line i+1 contains a single integer: heighti
输出
- Line 1: The minimum total amount of money that it will cost Farmer John to attach the new telephone wire.
样例输入
样例输出
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<queue>
#include<stack>
#include<ctime>
#include<vector>
using namespace std;
long long n,m;
long long a[],f[][],mmax;
int main()
{
long long i,j,k;
scanf("%lld%lld",&n,&m);
memset(f,/,sizeof(f));
for(i=;i<=n;i++)
{
scanf("%lld",&a[i]);
mmax=max(mmax,a[i]);
}
for(i=a[];i<=mmax;i++)
{
int s=i-a[];
f[][i]=s*s;
}
for(i=;i<=n;i++)
{
for(j=a[i-];j<=mmax;j++)
{
for(k=a[i];k<=mmax;k++)
{
int s=k-a[i];
f[i][k]=min(f[i][k],s*s+f[i-][j]+m*abs(j-k));
}
}
}
long long ans=;
for(i=a[n];i<=mmax;i++)
ans=min(ans,f[n][i]);
cout<<ans;
return ;
}
显然是需要优化的,仔细想一想就可以看出,每次实际上只有两种情况:
1.i-1的高度比i低。
2.i-1的高度比i高。
第一种情况下f[i][j]的结果为f[i-1][min]+abs(j-min)*k+(j-a[i])^2显然是有最小值的,所以只要记录min就可以直接算出f[i][j]的值。
第二种情况下f[i][j]的结果为f[i-1][min]+abs(j-min)*k+(j-a[i])^2,但由于随着j的增加每次min的值都有可能会改变,所以需要用到一个单调队列来记录最小值。
以下为AC代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<queue>
#include<stack>
#include<ctime>
#include<vector>
using namespace std;
long long n,m;
long long a[],f[][],mmax;
int main()
{
long long i,j,k;
scanf("%lld%lld",&n,&m);
memset(f,,sizeof(f));
for(i=; i<=n; i++)
{
scanf("%lld",&a[i]);
mmax=max(mmax,a[i]);
}
for(i=a[]; i<=mmax; i++)
{
int s=i-a[];
f[][i]=s*s;
}
for(i=; i<=n; i++)
{
int p[],head=,tail=,mmin=;
for(j=a[i-];j<a[i];j++)
{
if(f[i-][j]+abs(a[i]-j)*m<f[i-][mmin]+abs(a[i]-mmin)*m||mmin==)
mmin=j;
}
int ssss=max(a[i],a[i-]);
p[++tail]=ssss;
for(j=ssss+;j<=mmax;j++)
{
while(f[i-][j]+abs(j-a[i])*m<f[i-][p[tail]]+abs(p[tail]-a[i])*m&&head<=tail)tail--;
p[++tail]=j;
}
for(j=a[i];j<=mmax;j++)
{
f[i][j]=min(f[i][j],f[i-][mmin]+abs(j-mmin)*m+(j-a[i])*(j-a[i]));
f[i][j]=min(f[i][j],f[i-][p[head]]+abs(j-p[head])*m+(j-a[i])*(j-a[i]));
if(f[i-][mmin]-abs(j-mmin)*m>f[i-][j])mmin=j;
if(p[head]==j)head++;
}
}
long long ans=1e18;
for(i=a[n]; i<=mmax; i++)
ans=min(ans,f[n][i]);
cout<<ans;
return ;
}
[USACO07NOV]电话线Telephone Wire的更多相关文章
- P2885 [USACO07NOV]电话线Telephone Wire
P2885 [USACO07NOV]电话线Telephone Wire 最近,Farmer John的奶牛们越来越不满于牛棚里一塌糊涂的电话服务于是,她们要求FJ把那些老旧的电话线换成性能更好的新电话 ...
- P2885 [USACO07NOV]电话线Telephone Wire——Chemist
题目: https://www.luogu.org/problemnew/show/P2885 由于把每一根电线杆增加多少高度不确定,所以很难直接通过某种方法算出答案,考虑动态规划. 状态:f [ i ...
- [luoguP2885] [USACO07NOV]电话线Telephone Wire(DP + 贪心)
传送门 真是诡异. 首先 O(n * 100 * 100) 三重循环 f[i][j] 表示到第 i 个柱子,高度是 j 的最小花费 f[i][j] = min(f[i - 1][k] + abs(k ...
- 【USACO07NOV】电话线Telephone Wire
题目描述 电信公司要更换某个城市的网线.新网线架设在原有的 N(2 <= N <= 100,000)根电线杆上, 第 i 根电线杆的高度为 height_i 米(1 <= heigh ...
- [USACO 07NOV]电话线Telephone Wire
题目描述 Farmer John's cows are getting restless about their poor telephone service; they want FJ to rep ...
- 【动态规划】bzoj1705: [Usaco2007 Nov]Telephone Wire 架设电话线
可能是一类dp的通用优化 Description 最近,Farmer John的奶牛们越来越不满于牛棚里一塌糊涂的电话服务 于是,她们要求FJ把那些老旧的电话线换成性能更好的新电话线. 新的电话线架设 ...
- DP+滚动数组 || [Usaco2007 Nov]Telephone Wire 架设电话线 || BZOJ 1705 || Luogu P2885
本来是懒得写题解的…想想还是要勤发题解和学习笔记…然后就滚过来写题解了. 题面:[USACO07NOV]电话线Telephone Wire 题解: F[ i ][ j ] 表示前 i 根电线杆,第 i ...
- BZOJ_1705_[Usaco2007 Nov]Telephone Wire 架设电话线_DP
BZOJ_1705_[Usaco2007 Nov]Telephone Wire 架设电话线_DP Description 最近,Farmer John的奶牛们越来越不满于牛棚里一塌糊涂的电话服务 于是 ...
- bzoj1705[Usaco2007 Nov]Telephone Wire 架设电话线(dp优化)
1705: [Usaco2007 Nov]Telephone Wire 架设电话线 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 441 Solved: ...
随机推荐
- 做自己的PHP语法解释器
PHP关键字异构化实验 PHP词法分析和语法分析 简单理解PHP代码执行过程:http://blog.csdn.net/risingsun001/article/details/22888861 PH ...
- 利用GROUP_CONCAT和GROUP BY实现字段拼接
在开发过程中遇到这样的一个需求,通过GROUP BY分组归类后将同属性的字段进行拼接. 表结构为: id value a b c a b 需要得到结果: id value a,b,c a,b 一开始在 ...
- JS对select动态添加option操作 (三级联动) (搜索拼接)
以下纯属自我理解之下再东搜西查的内容~ JS对select动态添加option操作有个高大上的艺名叫多级联动:第一级改变时,第二级跟着变,第二级改变时,第三级跟着变... 本菜鸟是在工作中遇到做收货地 ...
- [笔记]机器学习(Machine Learning) - 02.逻辑回归(Logistic Regression)
逻辑回归算法是分类算法,虽然这个算法的名字中出现了"回归",但逻辑回归算法实际上是一种分类算法,我们将它作为分类算法使用.. 分类问题:对于每个样本,判断它属于N个类中的那个类或哪 ...
- synchronized 修饰在 static方法和非static方法的区别
Java中synchronized用在静态方法和非静态方法上面的区别 在Java中,synchronized是用来表示同步的,我们可以synchronized来修饰一个方法.也可以synchroniz ...
- Natas Wargame Level 17 Writeup(Time-based Blind SQL Injection)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAArIAAACUCAYAAABvE8qCAAAABHNCSVQICAgIfAhkiAAAIABJREFUeF
- PHP如何与搜索引擎Elasticsearch交互?
一:参考官方文档 1. Elasticsearch 5.4.0英文手册:https://www.elastic.co/guide/en/elasticsearch/reference/5.4/sear ...
- 网站权限管理 之 角(jue)色管理
公司或网站的正常运行,离不开管理员对各个员工的合理分配,那先看看权限管理中的角色管理好了: 要更改用户的角色,那么先来理一下思路: (1)用户现在是什么角色? (2)用户将要成为什么角色? (3)怎样 ...
- 使用redis做mybaties的二级缓存(2)-Mybatis 二级缓存小心使用
Mybatis默认对二级缓存是关闭的,一级缓存默认开启: 下面就说说为什么使用二级缓存需要注意: 二级缓存是建立在同一个namespace下的,如果对表的操作查询可能有多个namespace,那么得到 ...
- SparkMLlib学习之线性回归
SparkMLlib学习之线性回归 (一)回归的概念 1,回归与分类的区别 分类模型处理表示类别的离散变量,而回归模型则处理可以取任意实数的目标变量.但是二者基本的原则类似,都是通过确定一个模型,将输 ...