洛谷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;
}
相关推荐
kupeThinkPoem8 分钟前
跳表有哪些算法?
数据结构·算法
前端小L17 分钟前
图论专题(二十一):并查集的“工程应用”——拔线重连,修复「连通网络」
数据结构·算法·深度优先·图论·宽度优先
88号技师28 分钟前
2025年9月一区SCI-孤行尺蠖觅食优化算法Solitary Inchworm Foraging-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
前端小L1 小时前
图论专题(二十五):最小生成树(MST)——用最少的钱,连通整个世界「连接所有点的最小费用」
算法·矩阵·深度优先·图论·宽度优先
前端小L1 小时前
图论专题(二十三):并查集的“数据清洗”——解决复杂的「账户合并」
数据结构·算法·安全·深度优先·图论
CoovallyAIHub1 小时前
破局红外小目标检测:异常感知Anomaly-Aware YOLO以“俭”驭“繁”
深度学习·算法·计算机视觉
点云SLAM1 小时前
图论中邻接矩阵和邻接表详解
算法·图论·slam·邻接表·邻接矩阵·最大团·稠密图
啊董dong2 小时前
课后作业-2025年11月23号作业
数据结构·c++·算法·深度优先·noi
星释2 小时前
Rust 练习册 80:Grains与位运算
大数据·算法·rust
zzzsde2 小时前
【C++】C++11(1):右值引用和移动语义
开发语言·c++·算法