题解:AT_tdpc_iwi イウィ

区间 dp,还有点板。

Solution AT_tdpc_iwi

Idea

dpi,jdp_{i,j} 表示 [i,j][i,j] 最多能删多少字符。

则有:dpi,j=max{dpi,k+dpk+1,j}dp_{i,j}=\max\{dp_{i,k}+dp_{k+1,j}\},其中 ik<ji\le k<j

但是这样显然会错误。

考虑下面的情况:

[i+1,k1][i+1,k-1] 可以完全被删掉,[k+1,j1][k+1,j-1] 可以完全被删掉,(si,sk,sj)(s_i,s_k,s_j) 可以构成 iwi 时,显然可以先把 [i+1,k1][i+1,k-1][k+1,j1][k+1,j-1] 删掉,然后 (si,sk,sj)(s_i,s_k,s_j) 就会连在一起,然后可以直接删掉。对于这一部分,在代码中加一个特判即可。

最后,这道题比较远古,所以输出末尾务必要加换行。

Code

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N=305;
int dp[N][N],n;
string s;
int main(){
	cin>>s;
	n=s.length();
	s=' '+s;
	for(int len=1;len<=n;len++){
		for(int i=1,j=len;j<=n;i++,j++){
			for(int k=i;k<j;k++){
				dp[i][j]=max(dp[i][j],dp[i][k]+dp[k+1][j]);
				if(s[i]=='i'&&s[j]=='i'&&s[k]=='w'&&dp[i+1][k-1]==-(i+1)+(k-1)+1&&dp[k+1][j-1]==(j-1)-(k+1)+1)dp[i][j]=j-i+1;
			}
		}
	}
	printf("%d",dp[1][n]/3);
	return 0;
}
posted @   Weslie_qwq  阅读(1)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示