dp的一些练习
#include<iostream>
#include<vector>
using namespace std;
class Backpack
{
public:
int maxValue(vector<int> w, vector<int> v, int n, int cap)
{
int **dp=new int*[n];
for(int i=;i<n;i++)
dp[i]=new int[cap+]();
for(int i=;i<n;i++)
dp[i][]=;
for(int i=;i<cap+;i++)
{
if(i>=w[])
dp[][i]=v[];
else
dp[][i]=;
}
for(int i=;i<n;i++)
for(int j=;j<cap+;j++)
{
if((j-w[i])>=)
dp[i][j]=max(dp[i-][j],dp[i-][j-w[i]]+v[i]);
else
dp[i][j]=dp[i-][j];
}
int res=dp[n-][cap];
for(int i=;i<n;i++)
delete []dp[i];
delete []dp;
return res;
}
}; int main()
{
int a[]={,,,,,,,};
int b[]={,,,,,,,};
vector<int> arr(a,a+);
vector<int> brr(b,b+);
Backpack B;
cout<<B.maxValue(arr,brr,,);
return ;
}
#include<iostream>
#include<vector>
using namespace std;
class LCS {
public:
int findLCS(string A, int n, string B, int m)
{
int **dp=new int*[n];
for(int i=;i<n;i++)
dp[i]=new int[m];
for(int i=,temp=;i<n;i++)
{
if(B[]==A[i])
temp=;
dp[i][]=temp;
}
for(int i=,temp=;i<m;i++)
{
if(A[]==B[i])
temp=;
dp[][i]=temp;
}
for(int i=;i<n;i++)
for(int j=;j<m;j++)
{
//选择三种情况中dp[i][j]最大的
int m=max(dp[i-][j],dp[i][j-]);
if(A[i]==B[j])
m=max(dp[i-][j-]+,m);
dp[i][j]=m;
}
return dp[n-][m-];
}
}; int main()
{
string A="1A2C3D4B56",B="B1D23CA45B6A";
LCS f;
cout<<f.findLCS(A,,B,);
return ;
}
#include<iostream>
#include<vector>
using namespace std;
class LongestIncreasingSubsequence {
public:
int getLIS(vector<int> A, int n)
{
int *dp=new int[n],res=;
dp[]=;
for(int i=;i<A.size();i++)
{
int max=,j=;
while(j<i)
{
if(A[j]<A[i]&&dp[j]>max)
max=dp[j];
j++;
}
dp[i]=max+;
}
for(int i=;i<A.size();i++)
if(res<dp[i])
res=dp[i];
return res;
}
};
#include<iostream>
#include<vector>
using namespace std;
class MinimumPath {
public:
int getMin(vector<vector<int> > map, int n, int m)
{
int **dp=new int *[n];
for(int i=;i<n;i++)
dp[i]=new int[m];
for(int i=;i<n;i++)
for(int j=;j<m;j++)
dp[i][j]=;
dp[][]=map[][];
for(int i=;i<n;i++)
dp[i][]=dp[i-][]+map[i][];
for(int i=;i<m;i++)
dp[][i]=dp[][i-]+map[][i];
for(int i=;i<n;i++)
for(int j=;j<m;j++)
dp[i][j]=min(dp[i-][j],dp[i][j-])+map[i][j];
return dp[n-][m-];
}
};
class GoUpstairs {
public:
int countWays(int n)
{
int *dp=new int[n];
dp[]=;
dp[]=;
for(int i=;i<n;i++)
dp[i]=(dp[i-]+dp[i-])%Mod;
return dp[n-];
}
};
#include<iostream>
#include<vector>
using namespace std;
//动态规划
class Exchange {
public:
int countWays(vector<int> penny, int n, int aim)
{
if(n==||aim<)
return ;
int **map=new int*[n];
for(int i=;i<n;i++)
map[i]=new int[aim+];
for(int i=;i<n;i++)
for(int j=;j<aim+;j++)
map[i][j]=-;
for(int i=;i<n;i++)
map[i][]=;
for(int i=;i<aim+;i++)
if(i%penny[]==)
map[][i]=;
else
map[][i]=;
for(int i=;i<n;i++)
for(int j=;j<aim+;j++)
if((j-penny[i])>=)
map[i][j]=map[i][j-penny[i]]+map[i-][j];
else
map[i][j]=map[i-][j];
return map[n-][aim];
} }; /*记忆搜索
class Exchange {
public:
int countWays(vector<int> penny, int n, int aim)
{
if(n==0||aim<0)
return 0;
int **map=new int*[n];
for(int i=0;i<n;i++)
map[i]=new int[aim+1];
for(int i=0;i<n;i++)
for(int j=0;j<aim+1;j++)
map[i][j]=-1;
return process(penny,0,aim,map); }
int process(vector<int> arr,int index,int aim,int **map)
{
int res;
if(arr.size()-1==index)
{
if(map[index][aim]==-1)
map[index][aim]=(aim%arr[index])?0:1;
return map[index][aim];
}
else
{
res=0;
int k=aim/arr[index];
for(int i=0;i<=k;i++)
{
if(map[index+1][aim-i*arr[index]]==-1)
map[index+1][aim-i*arr[index]]=process(arr,index+1,aim-i*arr[index],map);
res+=map[index+1][aim-i*arr[index]];
}
}
return res;
}
};*/ /*暴力搜索
class Exchange {
public:
int countWays(vector<int> penny, int n, int aim)
{
if(n==0||aim<0)
return 0;
return process(penny,0,aim); }
int process(vector<int> arr,int index,int aim)
{
int res;
if(arr.size()-1==index)
{
res=(aim%arr[index])?0:1;
return res;
}
else
{
res=0;
int k=aim/arr[index];
for(int i=0;i<=k;i++)
res+=process(arr,index+1,aim-i*arr[index]);
}
return res;
}
};*/ int main()
{
int a[]={,,};
vector<int> arr(a,a+);
Exchange e;
cout<<e.countWays(arr,,); return ;
}
class MinCost {
public:
int findMinCost(string A, int n, string B, int m, int c0, int c1, int c2) //c0²åÈ룬c1ɾ³ý£¬c2Ìæ»»
{
int **dp=new int*[n+];
for(int i=;i<n+;i++)
dp[i]=new int[m+];
for(int i=;i<n+;i++)
dp[i][]=i*c1;
for(int i=;i<m+;i++)
dp[][i]=i*c0;
for(int i=;i<n+;i++)
for(int j=;j<m+;j++)
{
int temp1=,temp2=,res;
temp1=min(dp[i][j-]+c0,dp[i-][j]+c1);
if(A[i-]==B[j-])
temp2=dp[i-][j-];
else
temp2=dp[i-][j-]+c2;
res=min(temp1,temp2);
dp[i][j]=res;
}
return dp[n][m];
}
};
dp的一些练习的更多相关文章
- BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 4142 Solved: 1964[Submit][Statu ...
- 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...
- AEAI DP V3.7.0 发布,开源综合应用开发平台
1 升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...
- AEAI DP V3.6.0 升级说明,开源综合应用开发平台
AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...
- BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]
1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4026 Solved: 1473[Submit] ...
- [斜率优化DP]【学习笔记】【更新中】
参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...
- BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]
1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 9812 Solved: 3978[Submit][St ...
- px、dp和sp,这些单位有什么区别?
DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...
- android px转换为dip/dp
/** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public int dipTopx(Context context, float dpValue) { final floa ...
- POJ 3254. Corn Fields 状态压缩DP (入门级)
Corn Fields Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 9806 Accepted: 5185 Descr ...
随机推荐
- [C8] 聚类(Clustering)
聚类(Clustering) 非监督学习:简介(Unsupervised Learning: Introduction) 本章节介绍聚类算法,这是我们学习的第一个非监督学习算法--学习无标签数据,而不 ...
- 1.web2
听说聪明的人都能找到答案http://123.206.87.240:8002/web2/ 直接查看源码~~~
- (day48)Bootstrap、Adminlte框架、sweetalert
目录 Bootstrap框架官网 Adminlte框架官网 sweetalert 一.基础 二.布局 三.组件 四.插件 Bootstrap框架官网 Adminlte框架官网 sweetalert g ...
- layui实现分页
一 准备工作 首先必须先引入layui的完整目录,也就是你下载下来的整个layui的目录都要放在你的资源文件夹下,也就是这个文件目录 刚开始接触layui的时候,以为和jquery,vue等框架一样, ...
- Python接口自动化测试框架实战 从设计到开发
第1章 课程介绍(不要错过)本章主要讲解课程的详细安排.课程学习要求.课程面向用户等,让大家很直观的对课程有整体认知! 第2章 接口测试工具Fiddler的运用本章重点讲解如何抓app\web的htt ...
- [译][ABP vNext]ABP CLI,v0.18版本的新模板和其他功能
ABP CLI,v0.18版本的新模板和其他功能 ABP v0.18已发布, 包含解决的70+个issue,500+次提交 网站更改 abp.io网站完全更新以突出ABP框架的目标和重要功能.文档和博 ...
- 剑指offer:对称的二叉树(镜像,递归,非递归DFS栈+BFS队列)
1. 题目描述 /** 请实现一个函数,用来判断一颗二叉树是不是对称的. 注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的 */ 2. 递归 思路: /** 1.只要pRoot.left和 ...
- win10 mysql5.7.28 配置安装
如果有服务,使用下面命令删除,管理员身份打开cmd : sc delete mysql 1.下载 https://dev.mysql.com/downloads/mysql/5.7.html 没有的O ...
- Unity C# CSV文件解析与加载(已更新移动端处理方式)
在游戏开发过程中,经常要用到Excel编辑各类数据,如果可以直接用Excel支持的文件格式来读取数据,修改将非常便捷. Excel支持导出CSV类型的文件,这类文件不仅可以用Excel直接打开修改,即 ...
- Docker系列之学习笔记
一.Docker简介 1.1.Docker架构 Docker 使用客户端-服务器 (C/S) 架构模式,分为Docker守护进程和客户端,Docker 客户端,实际上是 docker 的二进制程序,D ...