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 ...
随机推荐
- ASP.NET开发实战——(十)ASP.NET MVC 与数据库之MySQL&EF
之前介绍EF时介绍了provider这个配置项,而且也介绍了在ASP.NET访问MySQL数据仍然是通过ADO.NET,不同的地方仅仅是更换了MySQL的数据提供器,那么在EF中是否也只需更换“提供器 ...
- JS分类选择插件
需要做一个选择分类工具,大致要求如下: 点击按钮,显示一级分类,指向某个一级分类显示对应二级分类,分类有几层不定. 只能选择最后一个分类,然后把分类的ID 传值给按钮的value 我的思路: 1.后台 ...
- C# 原子操作理解
C#内置提供的原子操作 Interlocked.Increment:以原子操作的形式递增指定变量的值并存储结果. Interlocked.Decrement:以原子操作的形式递减指定变量的值并存储结果 ...
- Azure DevOps Server(TFS) 客户端分析
Azure DevOps Server(TFS) 是微软公司的软件协作开发管理平台产品,为软件研发.测试.实施提供全流程的服务.作为一款应用服务器产品,他的客户端是什么,在哪里下载客户端?我们在项目实 ...
- QuantLib 金融计算——自己动手封装 Python 接口(1)
目录 QuantLib 金融计算--自己动手封装 Python 接口(1) 概述 QuantLib 如何封装 Python 接口? 自己封装 Python 接口 封装 Array 和 Matrix 类 ...
- 应用层内存溢出/越界/重复释放等问题检查工具(ASan)
https://github.com/google/sanitizers/wiki https://github.com/google/sanitizers/wiki/AddressSanitizer ...
- 奥展项目笔记06--js弹出框、对话框、提示框、弹窗总结
JS的三种最常见的对话框: //====================== JS最常用三种弹出对话框 ======================== //弹出对话框并输出一段提示信息 functi ...
- Reids Lua 模糊查询所有key 及 相对应的集合总数
Redis 使用 Lua 模糊查询所有key 及 相对应的集合总数 .Net 4.5.1 需要引入: StackExchange.Redis (测试用的 1.2.4.0) 方法一: 优点:原子 ...
- 使用 jQuery.TypeAhead 让文本框自动完成 (三)(服务器返回 JSON 复杂对象数组)
项目地址:https://github.com/twitter/typeahead.js 直接贴代码了: @section headSection { <script type="te ...
- Logstash:处理多个input
Logstash:处理多个input Logstash的整个pipleline分为三个部分: input插件:提取数据. 这可以来自日志文件,TCP或UDP侦听器,若干协议特定插件(如syslog或I ...