洛谷P4170 [CQOI2007] 涂色题解

题目传送门

思路

我们不难想到,本题是一道区间dp.

为区间[l,r]的最小涂色次数

很显然,的答案一定为1

当区间[i,j]的首尾不同时,即无法通过覆盖等方式减少涂色次数时,

当区间[i,j]的首尾相同时,如样例2的区间[1,5],首尾颜色都是R,我们就可以先全涂成R,再对区间[2,5]进行涂色,我们可以发现,最后的R(或第一个R)并没有消耗涂色次数,所以,由于一定不大于,所以我们并不需要进入循环取枚举分割点来再求一遍,这样可以减少一点时间复杂度

本题时间复杂度最大为

代码

cpp 复制代码
#include<bits/stdc++.h>
#define endl '\n';
using namespace std;
string s;
int n;
int f[60][60];
int main(){
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>s;
	int n=s.length();
	memset(f,0x3f,sizeof(f));
	for(int i=1;i<=n;i++)f[i][i]=1;
	for(int i=1;i<=n;i++){
		for(int j=1;j+i-1<=n;j++){
			int r=j+i-1;
			if(s[r-1]==s[j-1])f[j][r]=min(f[j][r],min(f[j+1][r],f[j][r-1]));
			else{
				for(int k=j;k<r;k++){
					f[j][r]=min(f[j][r],f[j][k]+f[k+1][r]);
				}
			}
		}
	}cout<<f[1][n];
	return 0;
}
相关推荐
前端 贾公子7 分钟前
《Vuejs设计与实现》第 5 章(非原始值响应式方案)下 Set 和 Map 的响应式代理
数据结构·算法
WWZZ20251 小时前
ORB_SLAM2原理及代码解析:SetPose() 函数
人工智能·opencv·算法·计算机视觉·机器人·自动驾驶
小马学嵌入式~2 小时前
堆排序原理与实现详解
开发语言·数据结构·学习·算法
青岛少儿编程-王老师2 小时前
CCF编程能力等级认证GESP—C++6级—20250927
java·c++·算法
一人の梅雨2 小时前
1688 拍立淘接口深度开发:从图像识别到供应链匹配的技术实现
人工智能·算法·计算机视觉
Miraitowa_cheems3 小时前
LeetCode算法日记 - Day 64: 岛屿的最大面积、被围绕的区域
java·算法·leetcode·决策树·职场和发展·深度优先·推荐算法
Christo33 小时前
关于K-means和FCM的凸性问题讨论
人工智能·算法·机器学习·数据挖掘·kmeans
_不会dp不改名_4 小时前
leetcode_1382 将二叉搜索树变平衡树
算法·leetcode·职场和发展
greentea_20134 小时前
Codeforces Round 173 B. Digits(2043)
c++·算法
m0_743106465 小时前
LOBE-GS:分块&致密化效率提升
人工智能·算法·计算机视觉·3d·几何学