1. 程式人生 > >UVAlive 6697 Homework Evaluation

UVAlive 6697 Homework Evaluation

can col sca 個數 博客 %d max esp 字符串

借鑒了別人的博客啊,自己寫寫給以後的自己看吧

給出兩個字符串,用第二個字符串去匹配第一個字符串,可以對第二個字符串進行刪除或插入操作,一位匹配成功得8分失敗-5分,如果插入或刪除,對於連續插入或刪除m個數減(4+m * 3)分。求最終得分的最大值。

用dp[i][j]表示第二個串的第i位和第一個串的第j位匹配得分的最大值,dp[i][j]可以是dp[i - 1][j - 1]繼續匹配也可能是dp[i - 1][k]通過插入一段串得到或者dp[k][j - 1]通過在第二個串刪除一段得到。最後掃描第二串匹配完的結果找最大值。

dp[i][j]分別代表第二串匹配到第一串匹配j的最大值

#include<bits/stdc++.h>

using
namespace std; const int N=200; int dp[N][N],n,m,T; char a[N],b[N]; int main(){ scanf("%d",&T); while(T--){ scanf("%s%s",a+1,b+1); n=strlen(a+1); m=strlen(b+1); for(int i=1;i<=m;i++){ dp[i][0]=-4-3*i; for(int j=1;j<=n;j++){ dp[i][j]
=dp[i-1][j-1]; for(int k=0;k<j-1;k++) dp[i][j]=max(dp[i][j],dp[i-1][k]-4-3*(j-k-1));//在第一串多添加 for(int k=0;k<i-1;k++) dp[i][j]=max(dp[i][j],dp[k][j-1]-4-3*(i-k-1));//在第二串多補上 if(a[j]==b[i]) dp[i][j]+=8; else
dp[i][j]-=5; } } int ans=dp[m][1]; for(int i=0;i<=n;i++) ans=max(ans,dp[m][i]); printf("%d\n",ans); } return 0; }

UVAlive 6697 Homework Evaluation