摘要: /*状态转移方程:re[i][j]=max(re[i-1][j],re[i][j-1],re[i-1][j-1]+(a[i]==b[j]))re[i][j]:长度为i的a串和长度为j的b串的公共最长子序列长度*/#define maxn 1006int re[maxn][maxn];int Max(int a,int b,int c){ if(a<b) a=b; if(a<c) a=c; return a;} int main(){ int t,i,j; char a[maxn],b[maxn]; scanf("%d... 阅读全文
posted @ 2013-04-30 22:44 小仪在努力~ 阅读(160) 评论(0) 推荐(0) 编辑
摘要: dp的思想,从前往后遍历字符串,更新不同长度的递增子序列的最小字符#include<iostream>#include<cstdio>#include<algorithm>#include<cmath>#include<cstring>#include<string>using namespace std;#define maxn 100006int a[maxn],b[maxn];int main(){ int n,i; while(~scanf("%d",&n)) { for(i=0;i&l 阅读全文
posted @ 2013-04-30 22:18 小仪在努力~ 阅读(143) 评论(0) 推荐(0) 编辑
摘要: 传统写法:string str; int count=0; cin>>str; int a[200]; a[0]=-999; //必须赋不属于str[i]的值 for(int i=0;i<str.length();++i) for(int j=count;j>=0;j--) //一个一个遍历维护a[j]的最小值 if((int)str[i]>a[j]) { a[j+1]=str[i]; ... 阅读全文
posted @ 2013-04-30 21:54 小仪在努力~ 阅读(180) 评论(0) 推荐(0) 编辑
摘要: dp的思想,从前往后遍历字符串,更新不同长度的递增子序列的最小字符二分的飘逸写法:#include<iostream>#include<cstdio>#include<algorithm>#include<cmath>#include<cstring>#include<string>using namespace std;int main(){ string a; int t,i,j; cin>>t; while(t--) { cin>>a; char b[10005]; //b[i]为了a字符串存 阅读全文
posted @ 2013-04-30 21:45 小仪在努力~ 阅读(134) 评论(0) 推荐(0) 编辑
摘要: 需要优化的01背包:#include<iostream>#include<cstdio>#include<algorithm>#include<cmath>#include<cstring>#include<string>using namespace std;int dp[100005];int main(){ int n,i,j,v,tv,w[30]; while(~scanf("%d",&n)) { for(i=0,v=0;i<n;++i) { scanf("%d" 阅读全文
posted @ 2013-04-30 19:51 小仪在努力~ 阅读(281) 评论(0) 推荐(0) 编辑
摘要: dp[i]:表示i长度有多少个符合的串1、i位置为0,则dp[i-1]都符合2、i位置为1,则i-1位置只能填0,则dp[i-2]都符合所以状态转移方程:dp[i]=dp[i-1]+dp[i-2];#include<iostream>#include<cstdio>#include<algorithm>#include<cmath>#include<cstring>#include<string>using namespace std;int main(){ int i,n,t,dp[45]={0,0,3,5}; for( 阅读全文
posted @ 2013-04-30 14:29 小仪在努力~ 阅读(264) 评论(0) 推荐(0) 编辑
摘要: 首先,我们考虑对于某个V容量,它能装下的苹果为1,2,3,但是装入的顺序无关紧要。然后我们模拟一下:对于某个苹果,能装下它的v更新dp数组#include<iostream>#include<cstdio>#include<algorithm>#include<cmath>#include<cstring>#include<string>using namespace std;struct apple{ int c,w;}a[1005];int dp[1005];int main(){ int v,n,i,j; while 阅读全文
posted @ 2013-04-30 13:41 小仪在努力~ 阅读(219) 评论(0) 推荐(0) 编辑
摘要: #include<cstdio>#include<iostream>#include<cstring>using namespace std;int dog[1005][12][12]; //dog[i][j][k] i表示时间,j表示横坐标,k表示纵坐标int g[1005][12][12];int m(int a,int b,int c,int d,int e){ if(a<b) a=b; if(a<c) a=c; if(a<d) a=d; if(a<e) a=e; return a;}int main(... 阅读全文
posted @ 2013-04-30 13:30 小仪在努力~ 阅读(128) 评论(0) 推荐(0) 编辑