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 ...
随机推荐
- JAVA多线程间隔时间段执行方法
import java.util.Date; import java.util.Timer; import java.util.TimerTask; public class ManyProject ...
- layer icon样式及 一些弹框使用方法
一.layer的icon样式 以上样式测试代码: layer.confirm('icon测试', {icon: 1, title:'提示'}, function(index){ //do someth ...
- 腾讯云短信服务+Node.js给手机发送验证码
最近公司需要些一个登陆验证和修改密码验证,需要用到验证码,我用Node.js写了一个给手机发验证码的代码,下面实现的功能有:生产验证码,(计时器)验证码失效时间,给手机发送短信. 首先看官方文档,在给 ...
- CSP-J&S2019第二轮游记认证
Day 0 我毕竟不是竞赛省,在黑龙江这个弱省任何初中都没有竞赛生的----在初中,文化课第一----永远如此. 因而,我并不能翘掉周五的文化课来复习或是提前前往省城参加下午2:00~6:00的试机. ...
- Jenkins安装第一个插件和通过离线安装包进行安装
1.打开左侧Manage Jenkins 选择Manage Plugins菜单 2.搜索Folders插件,该插件用于创建一个目录 3.点击安装进入插件安装状态,Jenkins会自动下载相关联的插件 ...
- git commit 提交失败
git commit -m 'xxx' 报错 报错信息 当前分支:master 远程分支:gitlib.xxx error: cannot spawn .git/hooks/commit-msg: N ...
- 【杂文】CSP2019蒟蒻AFO(假)记
[杂文]CSP2019蒟蒻AFO(假)记 [初赛前 N 天] 时间:2019-10-15 今晚 \(2012\) 的初赛题做到心态爆炸,选择考计算机基础知识一脸懵逼,填空和后面一道大模拟直接跳过,最后 ...
- tsconfig.json配置项详解
{ "compilerOptions": { "allowUnreachableCode": true, // 不报告执行不到的代码错误. "allo ...
- 算法初步---基本的数据结构(java为例)
最近搞算法,觉得超级吃力的,一直以为数学好的,数学可以考试满分,算法一定没什么问题,贱贱地,我发现我自己想多了,还是自己的基础薄弱吧,今天我来补补最基础的知识. 算法(Algorithm)是指解题方案 ...
- 北京麒麟会GITC
分享ppt:https://pan.baidu.com/s/1Aerqtbi8VpMiFGhfEMUtPQ http://bj.thegitc.com/#meeting-agenda