HDU 4960 (水dp)
Another OCD Patient
However, because Xiaoji's OCD is more and more serious, now he has a strange opinion that merging i successive pieces into one will cost ai. And he wants to achieve his goal with minimum cost. Can you help him?
By the way, if one piece is merged by Xiaoji, he would not use it to merge again. Don't ask why. You should know Xiaoji has an OCD.
The first line of each case is an integer N (0 < N <= 5000), indicating the number of pieces in a line. The second line contains N integers Vi, volume of each piece (0 < Vi <=10^9). The third line contains N integers ai (0 < ai <=10000), and a1 is always 0.
The input is terminated by N = 0.
5 6 2 8 7 1 0 5 2 10 20 0
10
题意:给出一串数字,把这串数字合并成对称的串,合并连续的一段串有相应的花费,问最下花费是多少。
sl : 很水的dp,但是tle 好几发, 因为我是跳到了下一个状态还保留了当前的状态。但是想法还是对的。就是枚举两端相等的字段和。
这样就有转移方程 dp【i】【j】=min(dp【i+t】【j-x】 ,dp[i][j]) 满足sigma(a[i] to a[i+t-1])==sigma(a[j-x+1] to a[j] ) .
开始傻比了的代码。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
using namespace std;
typedef long long LL;
const int MAX = +;
const int inf = 0x3f3f3f3f;
int dp[MAX][MAX]; LL sum[MAX];
int v[MAX],n,t[MAX],a[MAX];
inline void rdl(LL &n){
n = ;
char c = getchar();
while(c < '' || c > '') c = getchar();
while(c >= '' && c <= '') n *= , n += (c - ''),c = getchar();
}
inline void rd(int &n){
n = ;
char c = getchar();
while(c < '' || c > '') c = getchar();
while(c >= '' && c <= '') n *= , n += (c - ''),c = getchar();
}
int check(int L,int R,int d) {
if(L+d==R) return ;
LL sum1=sum[L+d]-sum[L-];
LL sum2=; int id=;
for(int i=R;i>L+d;i--) {
sum2+=v[i];
if(sum2>=sum1) {
id=R-i;
break;
}
}
if(sum2==sum1) return id;
else return -;
}
int dfs(int L,int R) {
if(L>=R) return ;
if(~dp[L][R]) return dp[L][R];
int ans=inf; int d;
for(int i=;i<=(R-L);i++) {
d=check(L,R,i);
if(d!=-) {
ans=min(ans,dfs(L+i+,R-d-)+a[i+]+a[d+]);
}
}
return dp[L][R]=ans;
} int main() {
while(scanf("%d",&n)==&&n) {
memset(sum,,sizeof(sum));
memset(dp,-,sizeof(dp));
for(int i=;i<=n;i++) {
rd(v[i]);
sum[i]=sum[i-]+v[i];
}
for(int i=;i<=n;i++) {
rd(a[i]);
}
int ans=dfs(,n);
printf("%d\n",ans);
}
return ;
}
随便改过的代码。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
using namespace std;
typedef long long LL;
const int inf = 0x3f3f3f3f;
const int MAX = +;
int dp[MAX][MAX],a[MAX],v[MAX];
LL sum[MAX];
int dfs(int L,int R) {
if(L>=R) return ;
if(~dp[L][R]) return dp[L][R];
LL sum1,sum2; int ans=a[R-L+];
for(int i=L,j=R;i<j;) {
sum1=sum[i]-sum[L-];
sum2=sum[R]-sum[j-];
if(sum1==sum2) {
ans=min(ans,dfs(i+,j-)+a[i-L+]+a[R-j+]);
i++; j--;
}
else if(sum1>sum2) j--;
else i++;
}
return dp[L][R]=ans;
}
int main() {
int n;
while(scanf("%d",&n)==&&n) {
memset(sum,,sizeof(sum));
for(int i=;i<=n;i++) {
scanf("%d",&v[i]);
sum[i]=sum[i-]+v[i];
}
for(int i=;i<=n;i++) {
scanf("%d",&a[i]);
}
memset(dp,-,sizeof(dp));
int ans=dfs(,n);
printf("%d\n",ans);
}
}
HDU 4960 (水dp)的更多相关文章
- Tickets HDU - 1260 水DP
		HDU - 1260 现在有n个人要买电影票,如果知道每个人单独买票花费的时间, 还有和前一个人一起买花费的时间,问最少花多长时间可以全部买完票. 直接dp就行,注意下输出和初始化 每次从dp[i-1 ... 
- HDU 4968 (水dp 其他?)
		+;],dp1[][],dp2[][]; map< memset(GPA,, ;i<=;i++) hash[i]=; ;i<=;i++) hash[i]=; ... 
- HDU 2084 数塔 (水DP)
		题意:.... 析:从下往上算即可,水DP. 代码如下: #pragma comment(linker, "/STACK:1024000000,1024000000") #incl ... 
- hdu 2571 命运(水DP)
		题意: M*N的grid,每个格上有一个整数. 小明从左上角(1,1)打算走到右下角(M,N). 每次可以向下走一格,或向右走一格,或向右走到当前所在列的倍数的列的位置上.即:若当前位置是(i,j), ... 
- HDU 4960 Another OCD Patient(记忆化搜索)
		HDU 4960 Another OCD Patient pid=4960" target="_blank" style="">题目链接 记忆化 ... 
- CodeForces 706C  Hard problem (水DP)
		题意:对于给定的n个字符串,可以花费a[i] 将其倒序,问是否可以将其排成从大到小的字典序,且花费最小是多少. 析:很明显的水DP,如果不是水DP,我也不会做.... 这个就要二维,d[2][max ... 
- hdu 4123 树形DP+RMQ
		http://acm.hdu.edu.cn/showproblem.php? pid=4123 Problem Description Bob wants to hold a race to enco ... 
- hdu 4507  数位dp(求和,求平方和)
		http://acm.hdu.edu.cn/showproblem.php?pid=4507 Problem Description 单身! 依旧单身! 吉哥依旧单身! DS级码农吉哥依旧单身! 所以 ... 
- hdu 3709   数字dp(小思)
		http://acm.hdu.edu.cn/showproblem.php?pid=3709 Problem Description A balanced number is a non-negati ... 
- 水dp第二天(背包有关)
		水dp第二天(背包有关) 标签: dp poj_3624 题意:裸的01背包 注意:这种题要注意两个问题,一个是要看清楚数组要开的范围大小,然后考虑需要空间优化吗,还有事用int还是long long ... 
随机推荐
- 使用dubbox开发REST应用
			新建项目,添加Maven支持. 在pom.xml中添加依赖. <dependency> <groupId>org.jboss.resteasy</groupId> ... 
- shell 2 解析
			---- shell 3 /home/oracle/utility/macro/call_autopurge_arch.sh Description: Call purge archive log f ... 
- hadoop-2.4.1集群搭建及zookeeper管理
			准备 1.1修改主机名,设置IP与主机名的映射 [root@xuegod74 ~]# vim /etc/hosts 192.168.1.73 xuegod73 192.168.1.74 xuegod7 ... 
- Redis和SpringDataRedis
			一.Redis简介  Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,运行在内存中,由ANSI C编写.企业开发通常采用Redis来实现缓存.同类的产品还有memcac ... 
- Java线程-线程的基本状态
			问题:线程有哪些基本状态?这些状态是如何定义的? 新建(new):新创建了一个线程对象. 可运行(runnable):线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法.该状 ... 
- Objective -C Object initialization 对象初始化
			Objective -C Object initialization 对象初始化 1.1 Allocating Objects 分配对象 Allocation is the process by w ... 
- iOS:swift :可选类型
			import UIKit /*: 可选类型 * 可选类型表示变量可以有值, 也可以没有值 * C 和 Objective-C 中并没有可选类型这个概念 * Swift中只有可选类型才可以赋值为nil ... 
- vue1.0生命周期
			<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ... 
- vb,wps,excel 分裂
			Sub 分列() '以空格为分隔符,连续空格只算1个.对所选中的单元格进行处理 Dim m As Range, tmpStr As String, s As String Dim x As Integ ... 
- 【译】x86程序员手册33-9.6中断任务和中断处理程序
			9.6 Interrupt Tasks and Interrupt Procedures 中断任务和中断处理程序 Just as a CALL instruction can call either ... 
