首页 > 其他分享 >Zuma

Zuma

时间:2023-08-11 11:34:41浏览次数:31  
标签:int 删掉 Zuma MaxN 区间 dp

Zuma

题意

每次可以删掉连续的一段回文串,删掉后两边的串会拼起来,问最少多少次可以删完整个串。

思路

区间 dp,对于一个区间 \([l,r]\),如果 \(a[l - 1] = a[r + 1]\) 那么 \([l - 1, r + 1]\) 是可以通过区间 \([l, r]\) 来删掉 \([l - 1, r + 1]\),而所用的次数肯定是相同的,因为 \(a[l - 1]、a[r + 1]\) 是可以拼到 \([l, r]\) 的回文串的,所以一起删掉就好了。然后要统计由两个串拼起来的答案,可以枚举分界线,分两边处理,随后转区间 dp 即可。

code

点击查看代码
#include <iostream>

using namespace std;

const int MaxN = 510;

int dp[MaxN][MaxN], a[MaxN], n;

int main() {
  cin >> n;
  for (int i = 1; i <= n; i++) {
    cin >> a[i], dp[i][i] = 1;
  }
  fill(dp[1], dp[n + 1], 1);
  for (int len = 2; len <= n; len++) {
    for (int i = 1, j = i + len - 1; j <= n; i++, j++) {
      dp[i][j] = a[i] == a[j] ? dp[i + 1][j - 1] : 1e9;
      for (int k = i; k < j; k++) {
        dp[i][j] = min(dp[i][j], dp[i][k] + dp[k + 1][j]);
      }
    }
  }
  cout << dp[1][n] << endl;
  return 0;
}

标签:int,删掉,Zuma,MaxN,区间,dp
From: https://www.cnblogs.com/ybtarr/p/17622569.html

相关文章

  • [刷题笔记] CF607B Zuma
    Problem貌似还是某场cfdiv1的BDescription一个数组\(a\),每次可以消掉其中的一个回文串,求至少经过几次操作能消掉字符串\(s\)?Solution我们发现本题满足大区间包含小区间的特性,即通过小区间可以推出大区间,符合区间dp。考虑状态转移,枚举一个区间\(l,r\),如果\(a_l=a_r\)则答案......
  • CF607B zuma
    从序列中每次消去回文串,问最少几次消除完 #include<iostream>#include<cstring>usingnamespacestd;constintN=503,inf=0x3f3f3f3f;intf[N][N],a[N],n;......
  • CodeForces 607B Zuma
    CF607BZumalink洛谷linkCodeForces题意Genos最近在他的手机上下载了祖玛游戏。在祖玛游戏里,存在\(n\)个一行的宝石,第\(i\)个宝石的颜色是\(C_i\)。这个游戏......