标签:Brackets int POJ2955 枚举 DP && include dp 105
很好的区间DP题。
需要注意第一种情况不管是否匹配,都要枚举k来更新答案,比如:
“()()()”:dp[0][5]=dp[1][4]+2=4,枚举k,k=1时,dp[0][1]+dp[2][5]=6,最后取最大值6.
第一层d相当于“长度”的含义,第二层枚举i,j就可以用i+d表示,通过这种方式枚举区间左右端点。
1 #include<cstdio> 2 #include<cstdlib> 3 #include<cstring> 4 #include<cmath> 5 #include<algorithm> 6 #include<iostream> 7 using namespace std; 8 int dp[105][105]; 9 char s[105]; 10 11 bool match(int l,int r){ 12 if(s[l]=='('&&s[r]==')') return 1; 13 if(s[l]=='['&&s[r]==']') return 1; 14 return 0; 15 } 16 17 int main(){ 18 while(~scanf("%s",s)&&s[0]!='e'){ 19 int len=strlen(s); 20 memset(dp,0,sizeof(dp)); 21 for(int d=1;d<len;d++) 22 for(int i=0;i<len-d;i++){ 23 int j=i+d; 24 if(match(i,j))//括号成功匹配 25 dp[i][j]=dp[i+1][j-1]+2; 26 for(int k=i;k<j;k++)//不管匹配是否成功,都要进行这步操作,保证最优解 27 dp[i][j]=max(dp[i][j],dp[i][k]+dp[k+1][j]); 28 } 29 printf("%d\n",dp[0][len-1]); 30 } 31 return 0; 32 }
标签:Brackets,int,POJ2955,枚举,DP,&&,include,dp,105 来源: https://www.cnblogs.com/yhxnoerror/p/16387068.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。