P4170 [CQOI2007]涂色

简介: P4170 [CQOI2007]涂色

文章目录

  • P4170 [CQOI2007]涂色
  • AC代码


P4170 [CQOI2007]涂色

本题链接:P4170 [CQOI2007]涂色

本博客给出本题截图

7.png

AC代码

代码解释:基础的一道涂色题,区间dp,f[i][j]表示讲区间[i, j]染成目标的色块所需要的最少次数,如果有s[i] == s[j],那么有f[i][j] = min(f[i + 1][j], f[i][j - 1]);,即只需要多染一个格子就可以了,不需要加次数,当s[i] != s[j]的时候,就分成两段去染色,取最小值即可


代码:

#include <iostream>
#include <algorithm>
#include <cstring>
#include <string>
using namespace std;
const int N = 55;
int f[N][N];
int main()
{
  string s;
  cin >> s;
  int n = s.size();
  memset(f, 0x3f, sizeof f);
  for (int i = 0; i < n; i ++ ) f[i][i] = 1;
  for (int len = 2; len <= n; len ++ )
    for (int i = 0; i + len - 1 < n; i ++ )
    {
      int j = i + len - 1;
      if (s[i] == s[j]) f[i][j] = min(f[i + 1][j], f[i][j - 1]);
      else
        for (int k = i; k < j; k ++ )
          f[i][j] = min(f[i][j], f[i][k] + f[k + 1][j]);
    }
  cout << f[0][n - 1] << endl;
  return 0;
}



目录
相关文章
|
9月前
【Leetcode -766.托普利茨矩阵 -771.宝石与石头】
【Leetcode -766.托普利茨矩阵 -771.宝石与石头】
38 0
|
2月前
力扣 790. 多米诺和托米诺平铺(一维dp)
力扣 790. 多米诺和托米诺平铺(一维dp)
|
2月前
|
Go C++ 算法
C/C++每日一练(20230404) 旋转排序数组最小值、石头剪刀布、三数之和
C/C++每日一练(20230404) 旋转排序数组最小值、石头剪刀布、三数之和
33 0
C/C++每日一练(20230404) 旋转排序数组最小值、石头剪刀布、三数之和
|
8月前
|
算法
算法:数字涂色
算法:数字涂色
Leecode 695. 岛屿的最大面积
Leecode 695. 岛屿的最大面积
26 0
洛谷P1162 填涂颜色——广搜
洛谷P1162 填涂颜色——广搜
58 0
771. 宝石与石头
 给你一个字符串 jewels 代表石头中宝石的类型,另有一个字符串 stones 代表你拥有的石头。 stones 中每个字符代表了一种你拥有的石头的类型,你想知道你拥有的石头中有多少是宝石。 字母区分大小写,因此 "a" 和 "A" 是不同类型的石头。   示例 1: 输入:jewels = "aA", stones = "aAAbbbb" 输出:3 示例 2: 输入:jewels = "z", stones = "ZZ" 输出:0   提示: 1 <= jewels.length, stones.length <= 50 jewels 和 stones 仅由英文字母组成
66 0
洛谷P3194 [HNOI2008]水平可见直线(计算几何+单调栈)
洛谷P3194 [HNOI2008]水平可见直线(计算几何+单调栈)
85 0
洛谷P3194 [HNOI2008]水平可见直线(计算几何+单调栈)
33.矩形覆盖
我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?
40 0