蓝桥杯 3. 涂色

题目描述

假设你有一条长度为 5 的木板,初始时没有涂过任何颜色。你希望把它的 5 个单位长度分别涂上红、绿、蓝、绿、红色,用一个长度为 5 的字符串表示这个目标:RGBGR

每次你可以把一段连续的木板涂成一个给定的颜色,后涂的颜色会覆盖先涂的颜色。

例如:

  • 第一次把木板涂成 RRRRR
  • 第二次涂成 RGGGR
  • 第三次涂成 RGBGR,达到目标

请你计算用尽量少的涂色次数达到目标。


输入描述

输入仅一行,包含一个长度为 n 的字符串,即涂色目标。字符串中的每个字符都是一个大写字母,不同的字母代表不同颜色,相同的字母代表相同颜色。

  • 1 ≤ n ≤ 50

输出描述

输出仅一行,包含一个整数,即最少的涂色次数。


输入输出样例

示例 1

输入
in 复制代码
AAAAA
输出
out 复制代码
1

c++代码

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

string str;
int n;
vector<vector<int>> dp;

int main() {
    cin >> str;
    n = str.size();
    dp = vector<vector<int>>(n, vector<int>(n, INT_MAX));
    for (int len = 1; len <= n; len++) {
        for (int i = 0; i + len - 1 < n; i++) {
            int j = i + len - 1;
            if (i == j) dp[i][j] = 1;
            else if (str[i] == str[j]) {
                int a = INT_MAX, b = INT_MAX;
                if (i + 1 < n) a = dp[i + 1][j];
                if (j - 1 >= 0) b = dp[i][j - 1];
                dp[i][j] = min(a, b);
                if (dp[i][j] == INT_MAX) dp[i][j] = 1;
            }
            else {
                for (int k = i; k < j; k++) {
                    dp[i][j] = min(dp[i][j], dp[i][k] + dp[k + 1][j]);
                }
            }
        }
    }
    cout << dp[0][n - 1];
    return 0;
}//by wqs
相关推荐
浅念-16 分钟前
LeetCode 回溯算法题——综合练习
数据结构·c++·算法·leetcode·职场和发展·深度优先·dfs
列星随旋1 小时前
线段树和树状数组的学习
学习·算法
楼田莉子1 小时前
C++17新特性:__had_include/属性/求值顺序规则
开发语言·c++·后端
我爱cope2 小时前
【Agent智能体4 | 智能体AI的应用】
数据库·人工智能·职场和发展
全糖可乐气泡水3 小时前
Codex适配国产信创环境安装部署与技术适配全解析
开发语言·git·python·算法·百度
h_a_o777oah3 小时前
状态机+划分型 DP :深度解析K-划分问题下 DP 状态的转移逻辑(洛谷P2679 P2331 附C++代码)
c++·算法·动态规划·acm·状态机dp·划分型dp·滚动数组优化
05候补工程师3 小时前
从算法理想向工程现实的跨越:SLAM 核心架构、思维误区与 Nav2 实战避坑指南
人工智能·算法·安全·架构·机器人
手写码匠4 小时前
Android 17 适配实战指南:新特性解读、隐私变更与迁移全攻略
人工智能·深度学习·算法·aigc
雪度娃娃4 小时前
Asio异步读写——连接的安全回收问题
开发语言·c++·安全·php
珊瑚里的鱼5 小时前
leetcode42雨水
算法·leetcode