T1

题目:codevs4815江哥的dp题a

codevs4815

一个简单的DP,注意开long long(不然会全WA),以及初始条件(这题有负数,所以要把f设成极小值.还要保证转移正确).

#include <iostream>
#include <cstdio>
#include <cstring>
#define ll long long
const int maxN = 1000 + 7;
using namespace std; ll f[maxN][maxN][2],w[maxN]; int main() {
ll n,k;
memset(f,-63,sizeof(f));
scanf("%lld%lld",&n,&k);
for(int i = 1;i <= n;++ i)
scanf("%lld",&w[i]);
for(int i = 0;i <= n;++ i) f[i][0][0] = 0;
for(int i = 1;i <= n;++ i) {
for(int j = 1;j <= k;++ j) {
f[i][j][0] = max(f[i - 1][j][0],f[i - 1][j][1]);
f[i][j][1] = max(f[i - 1][j - 1][0] + w[i],f[i][j][1]);
}
} printf("%lld",max(f[n][k][0],f[n][k][1]));
}

T2

题目:codevs1695 windows 2013

codevs1695

简单的DP,和上一个题差不多.注意题目中的开头先用

#include <iostream>
#include <cstring>
#include <cstdio>
#define ll long long
const int maxN = 100 + 7;
using namespace std; ll f[maxN][2],a[maxN],b[maxN],c[maxN],n;//f[i][0]当前用勺 f[i][1]当前用筷 int main() {
memset(f,0x3f,sizeof(f));
scanf("%lld",&n);
for(int i = 1;i <= n;++ i)
scanf("%lld%lld%lld",&a[i],&b[i],&c[i]);//勺子筷子i道菜a_i,b_i。交换c_i
f[1][1] = b[1];
f[1][0] = c[1] + a[1];
for(int i = 2;i <= n;++ i) {
f[i][0] = min(f[i - 1][1] + c[i] + a[i],f[i - 1][0] + a[i]);
f[i][1] = min(f[i - 1][0] + c[i] + b[i],f[i - 1][1] + b[i]);
}
printf("%lld",min(f[n][0],f[n][1]));
return 0;
}

luogu2066 机器分配

题目链接:luogu2066

设状态f[i][j]表示第i个公司分配j台的最佳答案.那么就由dp转移方程.

dp[i][j] =dp[i - 1][j - k] + w[i][k];

输出路径,用一个数组存下路径就OK了.这里要注意的是按字典序进行输出,.

#include <iostream>
#include <cstdio>
#include <queue>
#define ll long long
const int maxN = 20;
const int maxM = 20;
using namespace std; queue<ll>q;
ll n,m;
ll w[maxN][maxM],f[maxN][maxM],path[maxN][maxM][maxN]; int main() {
scanf("%lld%lld",&n,&m);
for(int i = 1;i <= n;++ i ){
for(int j = 1;j <= m;++ j) {
scanf("%lld",&w[i][j]);
}
}
for(int i = 1;i <= n;++ i ) {
for(int j = 0;j <=m ;++ j ) {
for(int k = 0;k <= j;++ k) {
if(f[i - 1][k] + w[i][j - k] > f[i][j]) {
f[i][j] = f[i - 1][k] + w[i][j - k];
for(int l = 1;l < i;l ++ )path[i][j][l] = path[i - 1][k][l];
path[i][j][i] = j - k;
}
}
}
}
printf("%d\n",f[n][m]);
for(int i=1;i<=n;i++) cout<<i<<" "<<path[n][m][i]<<endl;
return 0;
}

luogu 1564膜拜

luogu1564

先求出i - j人数差.设f[i]表示前i人最少的分配的数,然后就有dp方程

f[i] = min(f[i],f[j] + 1)(j满足一定的条件)

#include<cstdio>
#include<algorithm>
using namespace std; int n,m,a[2501],b[2501],f[2501]; int main()
{
int i;
scanf("%d%d",&n,&m);
for(i=1,x;i<=n;i++)
{
scanf("%d",&x);
if(x == 1)
a[i] = a[i - 1] + 1,b[i] = b[i - 1];
else
a[i] = a[i - 1],b[i] = b[i - 1] + 1;
}
for(i = 1;i <= n;i ++)
{
f[i] = i;
for(j = i;j >= 0;j --)
if(a[i] - a[j] == i - j || b[i] - b[j] == i - j || abs(b[i] - b[j] - a[i] + a[j]) <= m)
f[i] = min(f[i],f[j]+1);
}
printf("%d",f[n]);
return 0;
}

luogu1115最大字段和

luogu1115

f[i]表示第i个位置的最大字段和.然后得转移方程:f[i] = max(f[i - 1] + a[i],a[i])

用一个变量不断地记录maxn

#include <iostream>
#include <cstdio>
#include <cstring>
const int maxN = 200000 + 7;
using namespace std; int f[maxN],maxn = -0x7fffffff,a[maxN]; int main() {
int n;
scanf("%d",&n);
for(int i = 1;i <= n;++ i )
scanf("%d",&a[i]);
for(int i = 1;i <= n;++ i) {
f[i] = max(f[i - 1] + a[i],a[i]);
maxn = max(f[i],maxn);
}
printf("%d",maxn);
return 0;
}

poj2479 -- Maximum sum

poj2479

正反两边最大子段和,然后枚举断点即可.

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
using namespace std;
const int maxN = 50000 + 7; int f[maxN],a[maxN],dp[maxN],qwq[maxN],qaq[maxN]; int main() {
int T,n;
scanf("%d",&T);
while(T --) {
int Ans = -0x7fffffff;
scanf("%d",&n);
memset(f,0,sizeof(f));
memset(dp,0,sizeof(dp));
memset(qwq,0,sizeof(qwq));
memset(qaq,0,sizeof(qaq));
for(int i = 1;i <= n;++ i)
scanf("%d",&a[i]);
for(int i = 1;i <= n;++ i)
f[i] = max(f[i - 1] + a[i],a[i]),qwq[i] = max(f[i],qwq[i - 1]);
for(int j = n;j >= 1; -- j)
dp[j] = max(dp[j + 1] + a[j],a[j]),qaq[j] = max(dp[j],qaq [j - 1]);
for(int i = 1;i <= n;++ i) {
Ans = max(Ans,qwq[i] + qaq[i + 1]);
}
printf("%d\n",Ans);
}
}

DP入门练习的更多相关文章

  1. poj 3254 状压dp入门题

    1.poj 3254  Corn Fields    状态压缩dp入门题 2.总结:二进制实在巧妙,以前从来没想过可以这样用. 题意:n行m列,1表示肥沃,0表示贫瘠,把牛放在肥沃处,要求所有牛不能相 ...

  2. xbz分组题B 吉利数字 数位dp入门

    B吉利数字时限:1s [题目描述]算卦大湿biboyouyun最近得出一个神奇的结论,如果一个数字,它的各个数位相加能够被10整除,则称它为吉利数.现在叫你计算某个区间内有多少个吉利数字. [输入]第 ...

  3. 【dp入门题】【跟着14练dp吧...囧】

    A HDU_2048 数塔 dp入门题——数塔问题:求路径的最大和: 状态方程: dp[i][j] = max(dp[i+1][j], dp[i+1][j+1])+a[i][j];dp[n][j] = ...

  4. 数位dp入门 hdu2089 不要62

    数位dp入门 hdu2089 不要62 题意: 给定一个区间[n,m] (0< n ≤ m<1000000),找出不含4和'62'的数的个数 (ps:开始以为直接暴力可以..貌似可以,但是 ...

  5. POJ 2342 树形DP入门题

    有一个大学的庆典晚会,想邀请一些在大学任职的人来參加,每一个人有自己的搞笑值,可是如今遇到一个问题就是假设两个人之间有直接的上下级关系,那么他们中仅仅能有一个来參加,求请来一部分人之后,搞笑值的最大是 ...

  6. hdu3555 Bomb 数位DP入门

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3555 简单的数位DP入门题目 思路和hdu2089基本一样 直接贴代码了,代码里有详细的注释 代码: ...

  7. 【专章】dp入门

    动态规划(简称dp),可以说是各种程序设计中遇到的第一个坎吧,这篇博文是我对dp的一点点理解,希望可以帮助更多人dp入门. ***实践是检验真理的唯一标准,看再多文章不如自己动手做几道!!!*** 先 ...

  8. HDU 2084 数塔(简单DP入门)

    数塔 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submiss ...

  9. 树形dp 入门

    今天学了树形dp,发现树形dp就是入门难一些,于是好心的我便立志要发一篇树形dp入门的博客了. 树形dp的概念什么的,相信大家都已经明白,这里就不再多说.直接上例题. 一.常规树形DP P1352 没 ...

  10. 树形DP入门详解+题目推荐

    树形DP.这是个什么东西?为什么叫这个名字?跟其他DP有什么区别? 相信很多初学者在刚刚接触一种新思想的时候都会有这种问题. 没错,树形DP准确的说是一种DP的思想,将DP建立在树状结构的基础上. 既 ...

随机推荐

  1. PJzhang:百度网盘是如何泄露公司机密的?

    猫宁!!! 参考链接:https://mp.weixin.qq.com/s/PLELMu8cVleOLlwRAAYPVg 百度网盘在中国一家独大,百度超级会员具有很多特权,尤其是在下载速度上,是普通会 ...

  2. A - Wireless Network

    #include <cstdio> #include <algorithm> #include <cstring> #include <iostream> ...

  3. 怎么快速对DB里的所有email进行校验

    问题 由于业务上的需求,重新改写了校验email的正则表达式,同时DB里又迁移了其他数据库的数据,现在需要重新对DB里的所有email再校验一次,以排除掉不合法的email. DB里的数据很多,手动去 ...

  4. java数据结构----链表

    1.链表:链表是继数组之后第二种使用的最广泛的通用存储结构,它克服了数组的许多弊端:无序数组的查找慢问题,有序数组的插入慢问题,数组定义时的定长问题.它也可取代数组,作为其他数据结构的基础. 2.引用 ...

  5. redis集群模式

    1 弊端和优势 弊端:相比单机模式,集群模式会在节点之间同步数据,会降低20%-30%的性能,同时增加架构复杂性,提高硬件成本和学习成本. 优势:增加冗余,避免单点故障.单机模式如果要重启,必然会丢失 ...

  6. 子shell

    http://bbs.csdn.net/topics/392292455 https://www.cnblogs.com/daniaoge/p/6161821.html http://blog.csd ...

  7. 119 Pascal's Triangle II 帕斯卡三角形 II Pascal's Triangle II

    给定一个索引 k,返回帕斯卡三角形(杨辉三角)的第 k 行.例如,给定 k = 3,则返回 [1, 3, 3, 1].注:你可以优化你的算法到 O(k) 的空间复杂度吗?详见:https://leet ...

  8. Mysql5.7安装错误处理与主从同步及!

    basedir=/iddbs/mysql-5.7.16 datadir=/iddbs/mysql5.7/data3306 一.自定义Mysql.5.7版本免编译安装: 1.Db-server1安装前期 ...

  9. 我的NopCommerce之旅(8): 路由分析

    一.导图和基础介绍 本文主要介绍NopCommerce的路由机制,网上有一篇不错的文章,有兴趣的可以看看NopCommerce源码架构详解--对seo友好Url的路由机制实现源码分析 SEO,Sear ...

  10. office 导出问题

    就用程序池右击项目高级设置 应用程序池的项目中的标识改为 LocalSystem 启用32位应用程序设为true或false